`

getHibernateTemplate()和getSession()区别(转)

阅读更多

在Spring整合 Hibernate中,对dao层访问中提供了两个操作。

 

(1)protected final Session getSession() throws DataAccessResourceFailureException,IllegalStateException;

spring api的解释:

 

    Obtain a Hibernate Session, either from the current transaction or a new one. The latter is only allowed if the "allowCreate" setting of this bean'sHibernateTemplate is "true".

Note that this is not meant to be invoked from HibernateTemplate code but rather just in plain Hibernate code. Either rely on a thread-bound Session or use it in combination with releaseSession(org.hibernate.Session).

    In general, it is recommended to use HibernateTemplate, either with the provided convenience operations or with a custom HibernateCallback that provides you with a Session to work on. HibernateTemplate will care for all resource management and for proper exception conversion.

 

 

(2)public final HibernateTemplate getHibernateTemplate();

spring api的解释:

Note: The returned HibernateTemplate is a shared instance.

 

 

通过http://blog.csdn.net/fenixshadow/archive/2007/09/26/1802277.aspx的分析:可知getHibernateTemplate由spring管理,始终使用一个session连接数据库,而每次getSession()就会创建一个新的session连接数据库,不被spring管理。

 

转帖(一)http://blog.csdn.net/fenixshadow/archive/2007/09/26/1802277.aspx

都说Spring 和 Hibernate是绝配。今天有点小小心得,拿出来共享一下。

当我们费了九牛二虎之力终于把环境全配好之后,有一个问题摆在面前:
如何访问数据库?

通过继承HibernateDaoSupport我们有两个选择:
 getSession().createQuery("from Users");
getHibernateTemplate().find( "FROM Users);

用哪个呢?困惑啊。

网上找了找资料都是推荐用getHibernateTemplate,原因说的不是很清楚。

于是我做了如下测试:

分别循环调用getSession().createQuery("from Users");getHibernateTemplate().find( "FROM Users);
1000次
结果getSession()很快就包无法建立连接了。而getHibernateTemplate屁事没有可以跑完。

通过后台观察,使用getSession会在数据库中留下很多SQL*Net message from client的连接,终止测试后连接自动释放。
而getHibernateTemplate则从头到尾都使用一个连接。

难道是getSession()不会自动释放连接?

于是我又分别循环调用getSession().createQuery("from Users");getHibernateTemplate().find( "FROM Users);
5次
发现当前端程序一结束,getSession的5个连接立刻就释放了。结合前面1000次时终止测试后连接自动释放,可以说明getSession()是会自动释放连接的。

结论:
1、getSession()和getHibernateTemplate都可以自动释放连接(当然你的配置要正确),但是在一个线程内getSession会get很多个session(就是开很多个会话、连接),很可能导致数据库连接超过上限。所以推荐使用getHibernateTemplate。

2、如果有些语句无法用getHibernateTemplate实现,可以使用getHibernateTemplate.execute使用HibernateCallback回调接口。

另:可以设定HibernateTemplate的AllowCreate为True,并在finally中关闭Session。也可以将true作为参数传递到super.getSession(..)方法中取得Session。这样也可以,就是麻烦点。
参见:
http://springframework.org/docs/api/org/springframework/orm/hibernate3/HibernateTemplate.html
http://www.mxjava.com/blog/article.asp?id=246


请各位高手不吝赐教。


另:用myEclipse自动生成的HibernateDAO代码中。4.1.1版本的myEclipse自动生成的findById方法使用的是getSession方法获得连接,不过在6.0中已经修改为使用getHibernateTemplate方法。5.0的没有测试。

 

转帖(二)http://jeoff.blog.51cto.com/186264/133434

 

自动生成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 ;
}

分享到:
评论

相关推荐

    getHibernateTemplate

    与直接使用`getSession()`方法相比,`getHibernateTemplate()`具有以下显著特点: 1. **事务管理**:`getHibernateTemplate()`是Spring封装后的接口,它支持声明式事务管理。这意味着你无需手动开启和关闭事务,...

    getHibernateTemplate分页-模糊查询

    本文将详细介绍如何利用`getHibernateTemplate()`方法结合Spring框架进行分页查询和模糊查询。 #### 二、关键概念解释 1. **Hibernate**: 是一个开放源代码的对象关系映射(ORM)框架,它提供了从Java类到数据库表...

    HibernateTemplate及generator用法.docx

    现在,让我们深入探讨`getSession()`和`HibernateTemplate`的各种用法: 1. **getSession()的用法**: - 查询:`super.getSession().find()`, `super.getSession().createQuery()` - 保存:`super.getSession()....

    HibernateTemplate及generator用法.doc

    - 保存:`getSession().save()`, `getSession().update()`, `getSession().delete()` - Query的使用: - 可以设置参数,类似PreparedStatement - 判断结果,通过`list.size()`,如有值则通过`list.get(0)`获取 - ...

    hibernateDaoSupport类的运用实例

    2. **Session获取**:提供了`getSession()`方法来获取当前线程的`Session`对象,从而避免了手动管理`SessionFactory`和`Session`的过程。 3. **事务管理**:支持自动提交事务或者回滚事务,根据`hibernateTemplate`...

    常用的HQL语句!!!!

    int row = this.getSession().createQuery(hql).setString(0, "小李想").executeUpdate(); ``` 这里的`setString(0, "小李想")`用于设置参数,`0`表示参数的位置,与`?`在HQL中的位置相对应。 2. **HQL删除**: ...

    HibernateDaoSupport 与@Autowired

    2. `getHibernateTemplate()`: 返回一个`HibernateTemplate`实例,该模板类封装了许多常用的Hibernate操作,如保存、更新、删除和查询等,使得操作数据库变得更加简洁。 3. `getSession()`: 提供对当前事务上下文中...

    J2EE企业级项目开发-1期 07 Spring 使用技巧.doc

    - 通过`this.getHibernateTemplate().getSessionFactory().openSession();` - 通过`this.getSession();` 这两种方式获取Session后,同样需要使用`releaseSession(session)`释放资源。务必记住,多次查询而未释放...

    Struts spring hibernate整合

    为了进行数据库操作,通常会创建一个继承自`HibernateDaoSupport`的DAO类,这样可以直接使用`getSession()`方法进行操作。例如: ```java public class Dao extends HibernateDaoSupport { public List selectList...

    Spring使用技巧

    SSH框架是指Spring、Struts2和Hibernate这三种技术的组合使用,而本文档主要关注的是如何在这样的框架下利用DAO(Data Access Object)层来执行SQL操作。 ##### 1.1 获取数据库连接 在SSH框架中,通常会利用...

    使用pager-taglib实现分页显示的详细步骤

    this.getHibernateTemplate().save(user); } @Override public PageModel findAllUser(int offset, int pageSize) { // 获取总记录数 String queryCountHql = "select count(*) from User"; Query query = ...

    j2ee中struts+hibernate+spring+pager-taglib分页实例

    this.getHibernateTemplate().save(user); } public PageModel findAllUser(int offset, int pageSize) { // 获取总记录数 String queryCountHql = "select count(*) from User"; Query query = getSession...

    Hibernate3使用经验

    Session session = this.getHibernateTemplate().getSessionFactory().openSession(); Transaction tran = session.beginTransaction(); try { session.save(userManager); tran.commit(); } catch ...

Global site tag (gtag.js) - Google Analytics