【Hibernate】getHibernateTemplate与getSession的区别以及优缺点

getHibernateTemplate与getSession有什么区别以及优缺点

getHibernateTemplate已经封装好了一些基本的方法,可以直接去用,也就是template;而getSession只是获取一个数据工厂的session,然后大部分方法都需要自己写,加hql语句,然后用query方法执行。谈不上什么优点缺点,类似添加删除更新这样的操作可以直接用getHibernateTemplate来进行,而大部分带条件查询的就需要用getSession自己写了;

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

下面是HibernateTemplate的常用方法简介:

void delete(Object entity):删除指定持久化实例
deleteAll(Collection entities):删除集合内全部持久化类实例
find(String queryString):根据HQL查询字符串来返回实例集合
findByNamedQuery(String queryName):根据命名查询返回实例集合
get(Class entityClass, Serializable id):根据主键加载特定持久化类的实例
save(Object entity):保存新的实例
saveOrUpdate(Object entity):根据实例状态,选择保存或者更新
update(Object entity):更新实例的状态,要求entity是持久状态
setMaxResults(int maxResults):设置分页的大小

Hibernate封装了对数据库的例行操作,比单纯的jdbc的DAO,开发效率要高很多了。而Springframework对Hibernate的操作又进行了进一步的包装,又将开发效率提升不少。下面的例子是Spring自己给的petclinic的样本程序

package org.springframework.samples.petclinic.hibernate;

import java.util.Collection;

import org.springframework.dao.DataAccessException;
import org.springframework.orm.hibernate.support.HibernateDaoSupport;
import org.springframework.samples.petclinic.Clinic;
import org.springframework.samples.petclinic.Owner;
import org.springframework.samples.petclinic.Pet;
import org.springframework.samples.petclinic.Visit;

/**
 *
 * Hibernate封装了对数据库的例行操作,比单纯的 jdbc的DAO,开发效率要高很多。
 * 而Springframework对 Hibernate的操作又进行了进一步的包装,又将开发效率提升不少。
 *
 * 下面的例子是Spring自己给的petclinic的样本程序。
 *
 * Hibernate implementation of the Clinic interface.
 *
 * <p>The mappings are defined in " petclinic.hbm .xml",
 * located in the root of the classpath.
 */
public class HibernateClinic extends HibernateDaoSupport implements Clinic {

       public Collection getVets() throws DataAccessException {
             return getHibernateTemplate().find( "from Vet vet order by vet.lastName, vet.firstName");
      }

       public Collection getPetTypes() throws DataAccessException {
             return getHibernateTemplate().find( "from PetType type order by type.name");
      }

       public Collection findOwners(String lastName) throws DataAccessException {
             return getHibernateTemplate().find( "from Owner owner where owner.lastName like ?", lastName + "%");
      }

       public Owner loadOwner( int id) throws DataAccessException {
             return (Owner) getHibernateTemplate().load(Owner. class, new Integer(id));
      }

       public Pet loadPet( int id) throws DataAccessException {
             return (Pet) getHibernateTemplate().load(Pet. class, new Integer(id));
      }

       public void storeOwner(Owner owner) throws DataAccessException {
             getHibernateTemplate().saveOrUpdate(owner);
      }

       public void storePet(Pet pet) throws DataAccessException {
             getHibernateTemplate().saveOrUpdate(pet);
      }

       public void storeVisit(Visit visit) throws DataAccessException {
             getHibernateTemplate().saveOrUpdate(visit);
      }

}

区别:

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 ;
}
  • 2
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值