`
wm920
  • 浏览: 81148 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

DAO问题讨论的<结束>

阅读更多
上编是关于DAO的讨论问题,通过这个一个讨论在这一过程当中我们每一人持的不同的看法,我想的是不管怎么样的DAO分层与整合的设计,都要依据我们的软件项目来衡量,从软件的角度上来看,就是要开发一个很完美的,效率高,运行很稳定的软件,为我们的每一个客户服务,因为客户关心的是他们的数据与数据的安全,而不是在于你们使用的怎么的代码逻辑设计思想,今天我就来做一个DAO的全面的总结吧,首先通过一个JDBC首先的一个DAO整合方法,在这个DAO的整合方法中,把我们经常定义的小类DAO方法收样到大的DAO整合方法中来,进行他们的执行操作,包含对数据库的SQL的执行控制(指的SQL的执行次数,SQL每秒执行规定的数据量)能实现到这样的,能大大的减少我们的数据库的频繁执行SQL的操作,在这样大DAO方法包含了 数据的增加,删除,更新,修改在每个小DAO的方法中主要直接转进参数进来,大的DAO法执行了在把结果集给小DAO,这里说明,不是Service层,而是DAO,上一编中 有人讲是Serviece层,我在这里说不是它,而是DAO层。假如我们以后的业务修改了,我们的DAO就没有进行大刀的修改与操作,主要关心我们的业务控制逻辑层就是了。竟然我们的DAO可以这样写,那么我们的Service层可以这样写,不过要根据自己的软件要求。就这搁笔吧,请看代码如下:

<!!!-----------DAO--->
public abstract class BaseHibernateDao extends HibernateDaoSupport
{

    public BaseHibernateDao()
    {
    }

    protected abstract Class getEntityClass();

    public Object get(Serializable id)
    {
        Object o = getHibernateTemplate().get(getEntityClass(), id);
        if(o == null)
            throw new ObjectRetrievalFailureException(getEntityClass(), id);
        else
            return o;
    }

    public List getAll()
    {
        return getHibernateTemplate().loadAll(getEntityClass());
    }

    public void removeByHql(String hql)
    {
        Query q = getSession().createQuery(hql);
        q.executeUpdate();
    }

    public void save(Object o)
    {
        getHibernateTemplate().save(o);
    }

    public void update(Object o)
    {
        getHibernateTemplate().update(o);
    }

    public void remove(Serializable id)
    {
        remove(get(id));
    }

    public void remove(int id)
    {
        remove(get(new Integer(id)));
    }

    public void remove(Object o)
    {
        getHibernateTemplate().delete(o);
    }

    public List find(String hsql)
    {
        return getHibernateTemplate().find(hsql);
    }

    public List find(String hsql, Object value)
    {
        return getHibernateTemplate().find(hsql, value);
    }

    public List find(String hsql, Object values[])
    {
        return getHibernateTemplate().find(hsql, values);
    }

    public Object findBy(String name, Object value)
    {
        Criteria criteria = getSession().createCriteria(getEntityClass());
        criteria.add(Restrictions.eq(name, value));
        return criteria.uniqueResult();
    }

    public List findAllBy(String name, Object value)
    {
        Criteria criteria = getSession().createCriteria(getEntityClass());
        criteria.add(Restrictions.eq(name, value));
        return criteria.list();
    }

    public List findAllByLike(String name, Object value)
    {
        Criteria criteria = getSession().createCriteria(getEntityClass());
        criteria.add(Restrictions.like(name, value));
        return criteria.list();
    }

    public List findAllBy(Map filter)
    {
        Criteria criteria = getSession().createCriteria(getEntityClass());
        filterCriteria(criteria, filter);
        return criteria.list();
    }

    public Page pagedQuery(String hql, int pageNo, int pageSize)
    {
        return pagedQuery(hql, null, pageNo, pageSize);
    }

    public Page pagedQuery(String hql, Object args[], int pageNo, int pageSize)
    {
        int end = hql.indexOf("order");
        end = end != -1 ? end : hql.length();
        String sql = (new StringBuilder()).append("select count(*) as total ").append(hql.substring(hql.indexOf("from"), end)).toString();
        int total = 0;
        try
        {
            List l = getHibernateTemplate().find(sql, args);
            total = ((Integer)l.get(0)).intValue();
        }
        catch(Exception ex)
        {
            logger.error(ex);
        }
        return pagedQuery(hql, args, pageNo, pageSize, total);
    }

    public Page pagedQuery(String hql, Object args[], int pageNo, int pageSize, int total)
    {
        if(hql == null)
            throw new IllegalArgumentException("NULL is not a valid HQL string");
        Query query = getSession().createQuery(hql);
        if(args != null)
        {
            for(int i = 0; i < args.length; i++)
                query.setParameter(i, args[i]);

        }
        return HqlPage.getHibernatePageInstance(query, pageNo, pageSize, total);
    }

    public List findAllBy(Map filter, Map sortMap, int rowStart, int rowDisplayed)
    {
        Criteria criteria = getSession().createCriteria(getEntityClass());
        filterCriteria(criteria, filter);
        sortCriteria(criteria, sortMap);
        criteria.setProjection(null);
        criteria.setResultTransformer(CriteriaSpecification.ROOT_ENTITY);
        criteria.setFirstResult(rowStart);
        criteria.setMaxResults(rowDisplayed);
        return criteria.list();
    }

    protected void filterCriteria(Criteria criteria1, Map map)
    {
    }

    private void sortCriteria(Criteria criteria, Map sortMap)
    {
        if(!sortMap.isEmpty())
        {
            for(Iterator iterator = sortMap.keySet().iterator(); iterator.hasNext();)
            {
                String fieldName = iterator.next().toString();
                String orderType = sortMap.get(fieldName).toString();
                if("asc".equalsIgnoreCase(orderType))
                    criteria.addOrder(Order.asc(fieldName));
                else
                    criteria.addOrder(Order.desc(fieldName));
            }

        }
    }

    public int getCount(Map filter)
    {
        Criteria criteria = getSession().createCriteria(getEntityClass());
        filterCriteria(criteria, filter);
        Integer count = (Integer)criteria.setProjection(Projections.rowCount()).uniqueResult();
        return count.intValue();
    }

    protected final Log logger = LogFactory.getLog(getClass());
}

<!---DaoSupport---->

public class BaseHibernateSuport extends HibernateDaoSupport
{

    public BaseHibernateSuport()
    {
    }

    public int getCount(String hsql, Object obj[])
        throws HibernateException, SQLException
    {
        int total = 0;
        try
        {
            List l = getHibernateTemplate().find(hsql, obj);
            total = ((Integer)l.get(0)).intValue();
        }
        catch(Exception ex)
        {
            logger.error(ex);
        }
        return total;
    }

    public Vector swap(List list)
    {
        if(list != null)
        {
            Object obj = list.get(list.size() - 1);
            Vector ret = new Vector();
            ret.add(obj);
            list.remove(list.size() - 1);
            ret.addAll(list);
            return ret;
        } else
        {
            return null;
        }
    }
}

<!--DAO--->
public abstract class BaseDAO
{

    public BaseDAO()
    {
        conn = null;
        needClosed = null;
        isSharedCon = false;
        needClosed = new Vector();
        isSharedCon = false;
    }

    public Connection getCurrentConnection()
    {
        if(conn == null)
            conn = getConnection(CURRENTCONNECTIONSTYLE);
        return conn;
    }

    public Connection getConnection()
        throws SQLException
    {
        return getConnection(CURRENTCONNECTIONSTYLE);
    }

    public void setCurrentConnection(Connection conn)
        throws Exception
    {
        if(this.conn == null)
        {
            this.conn = conn;
        } else
        {
            closeConnection();
            this.conn = conn;
        }
    }

    public Connection getConnection(int style)
    {
        try
        {
            if(style == 0)
                conn = OaUtil.getConnection();
            else
            if(style == 1)
            {
                DriverManager.registerDriver(new OracleDriver());
                conn = DriverManager.getConnection((new StringBuilder()).append("jdbc:oracle:thin:@").append(hostname).append(":").append(port).append(":").append(dbSID).toString(), username, password);
            }
        }
        catch(Exception e)
        {
            System.out.println(e.toString());
            return null;
        }
        System.out.println("get database_connection successfully!");
        return conn;
    }

    public boolean begin()
        throws SQLException
    {
        if(isSharedCon)
            return true;
        if(conn == null)
            getCurrentConnection();
        conn.setAutoCommit(false);
        return true;
    }

    public boolean commit()
        throws SQLException
    {
        if(isSharedCon)
            return true;
        if(conn == null)
            getCurrentConnection();
        conn.commit();
        return true;
    }

    public boolean rollback()
        throws SQLException
    {
        if(isSharedCon)
            return true;
        if(conn == null)
            getCurrentConnection();
        conn.rollback();
        return true;
    }

    public ResultSet OpenSQL(String sql)
        throws SQLException
    {
        if(conn == null)
            getCurrentConnection();
        conn.setAutoCommit(true);
        Statement stmt = conn.createStatement(RESULTSETTYLE, RESULTSETCONCURRENCY);
        ResultSet rs = stmt.executeQuery(sql);
        needClosed.addElement(stmt);
        needClosed.addElement(rs);
        return rs;
    }

    public int executeSQL(String sql, boolean CommitAtOnce)
        throws SQLException
    {
        Statement stmt;
        int ret;
        stmt = null;
        ret = 0;
        if(conn == null)
            getCurrentConnection();
        if(CommitAtOnce)
            begin();
        stmt = conn.createStatement();
        ret = stmt.executeUpdate(sql);
        if(CommitAtOnce)
            commit();
        if(stmt != null)
            stmt.close();
        break MISSING_BLOCK_LABEL_106;
        Exception e;
        e;
        if(CommitAtOnce)
            rollback();
        if(stmt != null)
            stmt.close();
        break MISSING_BLOCK_LABEL_106;
        Exception exception;
        exception;
        if(stmt != null)
            stmt.close();
        throw exception;
        return ret;
    }

    public int executeSQL(String sql)
        throws SQLException
    {
        return executeSQL(sql, true);
    }

    public void closeConnection()
    {
        if(conn != null && !isSharedCon)
            try
            {
                for(int i = 0; i < needClosed.size(); i++)
                {
                    Object obj = needClosed.get(i);
                    if(obj instanceof Statement)
                    {
                        ((Statement)obj).close();
                        continue;
                    }
                    if(obj instanceof PreparedStatement)
                    {
                        ((PreparedStatement)obj).close();
                        continue;
                    }
                    if(obj instanceof ResultSet)
                        ((ResultSet)obj).close();
                }

                needClosed.clear();
                conn.close();
                conn = null;
            }
            catch(Exception e)
            {
                System.out.println((new StringBuilder()).append("baseDAO.closeConnection() exception:").append(e.toString()).toString());
            }
    }

    public abstract Object getFromRSCurRow(ResultSet resultset);

    public Vector getBeansFromResultSet(ResultSet rs)
    {
        Vector ret;
        ret = new Vector();
        for(; rs.next(); ret.addElement(getFromRSCurRow(rs)));
        return ret;
        Exception e;
        e;
        System.out.println((new StringBuilder()).append("BaseDAO.getBeansFromResultSet exception:").append(e.toString()).toString());
        return null;
    }

    public Vector getBeansFromResultSet(ResultSet rs, SearchInfo searchinfo)
    {
        if(!rs.next())
            return new Vector();
        Vector ret;
        int page;
        int row;
        int rowcount;
        ret = new Vector();
        page = searchinfo.getCurPage();
        if(page < 1)
            page = 1;
        row = (page - 1) * searchinfo.getPageSize() + 1;
        rowcount = 0;
        rowcount = 1;
_L1:
        if(rowcount >= row)
            break MISSING_BLOCK_LABEL_94;
        if(rs.next())
            break MISSING_BLOCK_LABEL_88;
        searchinfo.setCurPage(0);
        searchinfo.setRowsCount(rowcount);
        return ret;
        rowcount++;
          goto _L1
        int i = 0;
        i = 0;
        do
        {
            if(i >= searchinfo.getPageSize() && searchinfo.getPageSize() != 0)
                break;
            ret.addElement(getFromRSCurRow(rs));
            if(!rs.next())
                break;
            rowcount++;
            i++;
        } while(true);
        if(i != searchinfo.getPageSize())
            searchinfo.setPageSize(++i);
        searchinfo.setCurPage(page);
        while(rs.next())
            rowcount++;
        searchinfo.setRowsCount(rowcount);
        int tmpI = 0;
        if(rowcount == 0)
            tmpI = 0;
        else
        if(searchinfo.getPageSize() == 0)
        {
            tmpI = 1;
        } else
        {
            double tmpD = (double)rowcount / (double)searchinfo.getPageSize();
            tmpI = (int)tmpD;
            if(tmpD > (double)tmpI)
                tmpI++;
        }
        searchinfo.setPageCount(tmpI);
        return ret;
        Exception e;
        e;
        System.out.println((new StringBuilder()).append("BaseDAO.getBeansFromResultSet exception:").append(e.toString()).toString());
        return null;
    }

    public PreparedStatement createUpdateStatement(String sql)
    {
        PreparedStatement ret;
        if(conn == null)
            getCurrentConnection();
        ret = conn.prepareStatement(sql);
        needClosed.addElement(ret);
        return ret;
        Exception e;
        e;
        System.out.println((new StringBuilder()).append("BaseDAO.CreatePreparedStatement exception:").append(e.toString()).toString());
        return null;
    }

    public PreparedStatement createQueryStatement(String sql)
    {
        PreparedStatement ret;
        if(conn == null)
            getCurrentConnection();
        ret = conn.prepareStatement(sql);
        needClosed.addElement(ret);
        return ret;
        Exception e;
        e;
        System.out.println((new StringBuilder()).append("BaseDAO.CreatePreparedStatement exception:").append(e.toString()).toString());
        return null;
    }

    public ResultSet executeQuery(PreparedStatement prstms)
    {
        ResultSet rs;
        rs = prstms.executeQuery();
        needClosed.addElement(rs);
        return rs;
        Exception e;
        e;
        System.out.println((new StringBuilder()).append("BaseDAO. executeQuery exception:").append(e.toString()).toString());
        return null;
    }

    public int executeUpdate(PreparedStatement prstms)
    {
        int ret = prstms.executeUpdate();
        return ret;
        Exception e;
        e;
        System.out.println((new StringBuilder()).append("BaseDAO. executeupdate exception:").append(e.toString()).toString());
        return 0;
    }

    public Vector getNeedClosed()
    {
        return needClosed;
    }

    public void AddNeedClosed(Vector v)
    {
        needClosed.addAll(v);
    }

    public void ConnectTo(BaseDAO dao)
    {
        conn = dao.getCurrentConnection();
        needClosed = dao.getNeedClosed();
        isSharedCon = true;
    }

    public boolean getIsSharedConnection()
    {
        return isSharedCon;
    }


分享到:
评论

相关推荐

    j2ee17:servlet01:jsp结束,servlet的配置和生命周期

    在"Servlet01:jsp结束,servlet的配置和生命周期"这个主题中,我们将讨论以下几个关键知识点: 1. **Servlet简介**:Servlet是Java类,遵循Servlet接口,用于扩展服务器的功能,特别是Web服务器。它们可以接收和...

    JSP中JAVAVEAN实现简单分页!

    在分页查询时,DAO需要根据每页的起始位置和结束位置来构造SQL查询语句,比如: ```java String sql = "SELECT * FROM table LIMIT ?, ?"; PreparedStatement pstmt = connection.prepareStatement(sql); pstmt.set...

    jsp+servlet分页

    List&lt;Data&gt; dataList = dao.getPageData(currentPage, pageSize); request.setAttribute("dataList", dataList); request.setAttribute("currentPage", currentPage); request.setAttribute("totalPage", dao....

    daodao流程图1

    很抱歉,但根据您提供的信息,“daodao流程图1”的描述和标签中并没有具体的IT知识点,只有不可读的字符序列,这使得无法生成详细的知识点解释。通常,流程图在IT行业中可能涉及到软件开发的流程,比如敏捷开发的...

    MyBatis传入数组集合类并使用foreach遍历

    public List&lt;User&gt; getUsersByCollection(Collection collection); } ``` 这个方法接受一个Collection类型的参数,用于传递数组或集合类。 在Mapper文件中,我们可以使用foreach标签来遍历集合类,例如: ```xml ...

    Java Web程序运用中泛型DAO的作用.pdf

    泛型DAO模式通过抽象化设计,增强了程序的复用性和简化了编程语言,同时在程序运行结束后进行类型检查,避免了运行时的问题,并提高了运行速度。 文章进一步讨论了泛型DAO模式的查询功能设计。查询功能是泛型DAO...

    EMS.rar_dao persist_ems java

    其次,持久化(Persist)是将数据保存到非易失性存储(如硬盘)上的过程,使得数据在程序运行结束或系统重启后仍然存在。在Java中,JPA(Java Persistence API)和Hibernate是常用的持久化框架。JPA是Java官方提供的...

    WT-Assignment:网络技术分配GR-8

    HTML文档由一系列的元素组成,每个元素都有自己的开始和结束标签,如`&lt;p&gt;`(段落)和`&lt;img&gt;`(图像)。HTML5是目前广泛使用的版本,增加了许多新特性,如离线存储、音频/视频处理以及更好的表单控件等,大大提升了...

    最新各大公司企业真实面试题-华为笔试JAVASQL.doc

    在逻辑推理方面,我们可以讨论一些逻辑推理问题,例如分析问题和逻辑证明等。在这个例子中,我们可以讨论一个逻辑推理问题:A 到 B 的店去买香烟。A 付给 B100 元,但 B 无零钱找补,就拿去 C 处兑换零钱;B 回来将...

    会议纪要--20190703[01]1

    会议结束后,这些决策被正式传达给了服务器端软件开发小组,他们可以根据这些信息开始初步的开发工作。通过这样的协作方式,团队可以确保每个部分的工作都能按计划进行,从而提高项目的整体进度和质量。 总结来说,...

    iBATIS实战

    书中既详实地介绍了iBATIS的设计理念和基础知识,也讨论了动态SQL、高速缓存、DAD框架等高级主题,还讲解了iBATIS在实际开发中的应用。书的最后给出了一个设计优雅、层次清晰的示例程序JGameStore,该示例涵盖全书的...

    JAVA与数据库实训总结.pdf

    实训期间,我保持了良好的学习态度,准时出勤,积极参与讨论,及时完成日报,主动帮助同学解决问题。通过这次实训,我对SSM框架有了更深的认识,理解了session和cookie的使用,掌握了图片验证码、MD5加密和过滤器等...

    java秒杀项目源码-seckill:Java高并发秒杀API之业务分析与DAO层源码和整理的笔记seckill是项目源码note是整理的笔记

    这里我们将围绕"java秒杀项目源码-seckill"这个项目进行详细的分析和讨论。 首先,`seckill`项目源码是基于Java实现的秒杀系统的业务层代码,包含了处理秒杀业务的核心逻辑。项目中通常会包含以下几个关键模块: 1...

    使用StrutsSpringTestCase测试框架报错

    下面将详细讨论这些可能出现的问题以及解决方法。 首先,让我们了解一下Struts和Spring框架的基本概念。Struts是一个基于MVC(模型-视图-控制器)架构的Java Web框架,主要用于处理HTTP请求和控制业务逻辑。而...

    dhtmlxscheduler增删改查.zip

    接着,我们讨论一下** dao, service, action, model, pageModel**这些概念,它们是软件开发中的常见组成部分: 1. **DAO (Data Access Object)**:数据访问对象是用于处理数据库交互的类,它将业务逻辑与数据操作...

    JAVA程序员面试经验.pdf,这是一份不错的文件

    【Java程序员面试知识点...6. **结束面试**:最后阶段,表现出对公司和职位的热情,提出高质量的问题,礼貌道别。 这些面试知识点和技巧对于准备Java程序员的面试至关重要,全面理解和熟练掌握将大大提升面试成功率。

    JAVA实训心得.pdf

    在实训中遇到问题并解决问题的过程,也是学习的重要部分。尽管在数据库连接和数据插入上遇到了困难,但通过不断地尝试和调试,学员们逐渐理解了这些技术的精髓。尽管最终没有完全解决,但这种坚持和探索的精神对于...

    基于SSM的汉服文化交流平台源码.zip

    可能有文章实体类、评论实体类,以及相应的服务和DAO接口,用于CRUD操作。前端页面则使用模板引擎如FreeMarker或Thymeleaf渲染,提供良好的用户体验。 活动发布功能可能涉及到事件管理,用户可以创建、参与、查看...

    ASP药店管理系统设计(设计说明书+源代码+开题报告+结题PPT).zip

    在这个案例中,开题报告可能会讨论药店管理的现状、问题以及ASP技术的优势,明确系统开发的目标和计划。 结题PPT是项目结束时的总结,通常包含项目完成情况、主要成果、遇到的问题及解决方案、未来改进方向等内容。...

Global site tag (gtag.js) - Google Analytics