SSH的项目中,使用getHibernateTemplate 与 getSession有什么的区别?

1.

getHibernateTemplate已经封装好了一些基本的方法,可以直接去用

而getSession只是获取一个数据工厂的session,然后大部分方法都需要自己写,加hql语句,然后用query方法执行

2.

HibernateTemplate 提供非常多的常用方法来完成基本的操作,比如通常的增加、删除、修改、查询等操作,Spring 2.0更增加对命名SQL查询的支持,也增加对分页的支持。大部分情况下,使用Hibernate的常规用法,就可完成大多数DAO对象的CRUD操作。 下面是HibernateTemplate的常用方法简介:

qvoiddelete(Objectentity):删除指定持久化实例

qdeleteAll(Collectionentities):删除集合内全部持久化类实例

qfind(StringqueryString):根据HQL查询字符串来返回实例集合

qfindByNamedQuery(StringqueryName):根据命名查询返回实例集合

qget(ClassentityClass,Serializableid):根据主键加载特定持久化类的实例

qsave(Objectentity):保存新的实例

qsaveOrUpdate(Objectentity):根据实例状态,选择保存或者更新

qupdate(Objectentity):更新实例的状态,要求entity是持久状态

q setMaxResults(int maxResults):设置分页的大小

3.

使用getSession()方法你只要继承 sessionFactory,而使用getHibernateTemplate()方法必须继承HibernateDaoSupport当然包括 sessionFactory

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 ; }

相关推荐