1.
getHibernateTemplate已经封装好了一些基本的方法,可以直接去用
而getSession只是获取一个数据工厂的session,然后大部分方法都需要自己写,加hql语句,然后用query方法执行
2.
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):设置分页的大小
例如如下代码:
- 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 回调的方法管理数据库.
例如如下代码:
- 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());//[b]执行普通sql[/b]
- Query query = s.createQuery(sb.toString());//[b]执行hql [/b]
- List list = query.list();
- return list ;
- }
- });
- }
- </span>
推荐使用回调函数!