自动生成hibernate配置文件的时候,会在dao层用到getSession()方法来操作数据库记录,但是他还有个方法getHibernateTemplate(),这两个方法究竟有什么区别呢?
1.使用getSession()方法你只要继承sessionFactory,而使用getHibernateTemplate()方法必须继承 HibernateDaoSupport当然包括sessionFactory,这点区别都不是特别重要的,下面这些区别就很重要了
2.getSession()方法是没有经过spring包装的,spring会把最原始的session给你,在使用完之后必须自己调用相应的 close方法,而且也不会对声明式事务进行相应的管理,一旦没有及时关闭连接,就会导致数据库连接池的连接数溢出,getHibernateTemplate()方法是经过spring封装的,例如添加相应的声明式事务管理,由spring管理相应的连接。
在实际的使用过程中发现的确getHibernateTemplate()比getSession()方法要好很多,但是有些方法在getHibernateTemplate()并没有提供,这时我们用HibernateCallback 回调的方法管理数据库.
例如如下代码:
/**
     * 使用 hql 语句进行操作
     * @param hql HSQL 查询语句(使用回调函数访问外部变量,必须是final的)
     * @param offset 开始取数据的下标
    * @param length 读取数据记录数
    * @return List 结果集
*/
public List getListForPage ( final String hql , final int offset , final int length ) {
              List list = getHibernateTemplate().executeFind ( new HibernateCallback ( ) {
                            public Object doInHibernate ( Session session ) throws HibernateException, SQLException {
                                            Query query = session.createQuery ( hql ) ;
                                            query.setFirstResult ( offset ) ;
                                            query.setMaxResults ( length ) ;
                                            List list = query.list ( ) ;
                                            return list ;
                           }
               }) ;
               return list ;
}

最新文章

  1. Zip 压缩和解压技术在 HTML5 中的应用
  2. ubuntu mysql使用
  3. sphinx应用
  4. GDB调试D语言
  5. RMQ算法模板
  6. Linux JDK 安装及卸载 http://www.cnblogs.com/benio/archive/2010/09/14/1825909.html
  7. android开发--数据库(更新或者降低版本)
  8. js 阻止浏览器默认行为
  9. Codeforces 549B. Looksery Party[构造]
  10. AX Dynamics 去中文字符长度:中文字符当2个字符处理
  11. Markdown 使用说明
  12. 深入剖析哪些服务是Oracle 11g必须开启的
  13. Pods was rejected as an implicit dependency for 'libPods.a' because its architectures 'x86_64' didn
  14. Linq无聊练习系列6--Any/All/Contains/Concat/Union/Intersect/Except/take/skip/SqlMethods操作练习
  15. xlsx导入成--json
  16. 如何实现 集群化/Session 复制-doc(cluster-howto.html)
  17. java 关闭钩子函数的应用
  18. IDEA 配置远程debug
  19. 洗礼灵魂,修炼python(54)--爬虫篇—urllib2模块
  20. WifiMonitor的事件发放

热门文章

  1. CentOS查看CPU、内存、网络流量和磁盘 I/O
  2. 检测delphi的程序的内存泄漏
  3. 关于ajax发送的数据问题
  4. 定制样式插入到ueditor
  5. SQL Server 连接和事务相关的问题。
  6. Java application 性能分析分享
  7. js的数组操作
  8. linux之SQL语句简明教程---DROP TRUNCATE
  9. 【LeetCode练习题】Copy List with Random Pointer
  10. SQL中如何使用UPDATE语句进行联表更新(转)