getHibernateTemplate()与getSession()的区别
2016-01-21 17:13
555 查看
1.
getHibernateTemplate已经封装好了一些基本的方法,可以直接去用
而getSession只是获取一个数据工厂的session,然后大部分方法都需要自己写,加hql语句,然后用query方法执行
2.
HibernateTemplate 提供非常多的常用方法来完成基本的操作,比如通常的增加、删除、修改、查询等操作,Spring 2.0更增加对命名SQL查询的支持,也增加对分页的支持。大部分情况下,使用Hibernate的常规用法,就可完成大多数DAO对象的CRUD操作。 下面是HibernateTemplate的常用方法简介:
q void delete(Object entity):删除指定持久化实例
q deleteAll(Collection entities):删除集合内全部持久化类实例
q find(String queryString):根据HQL查询字符串来返回实例集合
q findByNamedQuery(String queryName):根据命名查询返回实例集合
q get(Class entityClass, Serializable id):根据主键加载特定持久化类的实例
q save(Object entity):保存新的实例
q saveOrUpdate(Object entity):根据实例状态,选择保存或者更新
q update(Object entity):更新实例的状态,要求entity是持久状态
q setMaxResults(int maxResults):设置分页的大小
例如如下代码:
[java]
view plain
copy
getHibernateTemplate().find():
List list = getHibernateTemplate().find(String sql ):
</span>
这种的前提是sql必须是hql ,原始sql 不能执行。
3.
使用getSession()方法你只要继承 sessionFactory,而使用getHibernateTemplate()方法必须继承HibernateDaoSupport当然包括 sessionFactory
getSession()方法是没有经过spring包装 的,spring会把最原始的session给你,在使用完之后必须自己调用相应的close方法,而且也不会对声明式事务进行相应的管理,一旦没有及时 关闭连接,就会导致数据库连接池的连接数溢出,getHibernateTemplate()方法是经过spring封装的,例如添加相应的声明式事务管 理,由spring管理相应的连接。
在实际的使用过程中发现的确getHibernateTemplate()比getSession()方法要好很多,但是有些方法在getHibernateTemplate()并没有提供,这时我们用HibernateCallback 回调的方法管理数据库.
例如如下代码:
[java]
view plain
copy
public List getList(){
return (List) getHibernateTemplate().execute(
new HibernateCallback() {
public List doInHibernate(final Session s)
throws HibernateException, SQLException {
StringBuffer sb = new StringBuffer();
Query query = s.createSQLQuery(sb.toString());//执行普通sql
Query query = s.createQuery(sb.toString());//执行hql
List list = query.list();
return list ;
}
});
}
</span>
采用这种做法的好处是:不用关心事务。session的创建和销毁,一切都在程序内部完成。看看名字doInHibernate就知道好处了。不好的是程序看起来比较乱!
推荐使用回调函数!
getHibernateTemplate已经封装好了一些基本的方法,可以直接去用
而getSession只是获取一个数据工厂的session,然后大部分方法都需要自己写,加hql语句,然后用query方法执行
2.
HibernateTemplate 提供非常多的常用方法来完成基本的操作,比如通常的增加、删除、修改、查询等操作,Spring 2.0更增加对命名SQL查询的支持,也增加对分页的支持。大部分情况下,使用Hibernate的常规用法,就可完成大多数DAO对象的CRUD操作。 下面是HibernateTemplate的常用方法简介:
q void delete(Object entity):删除指定持久化实例
q deleteAll(Collection entities):删除集合内全部持久化类实例
q find(String queryString):根据HQL查询字符串来返回实例集合
q findByNamedQuery(String queryName):根据命名查询返回实例集合
q get(Class entityClass, Serializable id):根据主键加载特定持久化类的实例
q save(Object entity):保存新的实例
q saveOrUpdate(Object entity):根据实例状态,选择保存或者更新
q update(Object entity):更新实例的状态,要求entity是持久状态
q setMaxResults(int maxResults):设置分页的大小
例如如下代码:
[java]
view plain
copy
getHibernateTemplate().find():
List list = getHibernateTemplate().find(String sql ):
</span>
这种的前提是sql必须是hql ,原始sql 不能执行。
3.
使用getSession()方法你只要继承 sessionFactory,而使用getHibernateTemplate()方法必须继承HibernateDaoSupport当然包括 sessionFactory
getSession()方法是没有经过spring包装 的,spring会把最原始的session给你,在使用完之后必须自己调用相应的close方法,而且也不会对声明式事务进行相应的管理,一旦没有及时 关闭连接,就会导致数据库连接池的连接数溢出,getHibernateTemplate()方法是经过spring封装的,例如添加相应的声明式事务管 理,由spring管理相应的连接。
在实际的使用过程中发现的确getHibernateTemplate()比getSession()方法要好很多,但是有些方法在getHibernateTemplate()并没有提供,这时我们用HibernateCallback 回调的方法管理数据库.
例如如下代码:
[java]
view plain
copy
public List getList(){
return (List) getHibernateTemplate().execute(
new HibernateCallback() {
public List doInHibernate(final Session s)
throws HibernateException, SQLException {
StringBuffer sb = new StringBuffer();
Query query = s.createSQLQuery(sb.toString());//执行普通sql
Query query = s.createQuery(sb.toString());//执行hql
List list = query.list();
return list ;
}
});
}
</span>
采用这种做法的好处是:不用关心事务。session的创建和销毁,一切都在程序内部完成。看看名字doInHibernate就知道好处了。不好的是程序看起来比较乱!
推荐使用回调函数!
相关文章推荐
- 安全驾驶-锁车门(三十二)
- 计数单位-科学计数法
- 讲解 Spark API 最好的资料
- Windows Embedded Compact 实时调度介绍
- makefile "="和“:=”的区别
- Android开发记录20-获取缓存大小和清除缓存功能
- Sql Server性能调试方法
- Home键屏蔽
- geoserver 的缓存技术
- servlet servlet请求与响应
- duplicate symbols for architecture x86_64
- new\new[]\delete\delete[]区别
- 0121 --view 可以当作线
- thinkphp读取配置文件中的数据
- 【基础】——云平台
- OJ 系列之24点游戏算法
- 安全驾驶-携带拖车绳(三十一)
- zookeeper(三) 应用场景
- 如何解决iOS界面操作导致导致NSTimer暂停计时的问题?
- C#向Sql数据库插入控制