您的位置:首页 > 其它

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

2010-04-21 23:36 375 查看
SSH的项目中,使用getHibernateTemplate

getSession有什么的区别?优点与缺点是什么,

getHibernateTemplate

经封装好了一些基本的方法,可以直接去用,也就是template嘛,

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

谈不上什么优点缺点,类似添加删除更新这样的可以直接用getHibernateTemplate
而大部分带条件查询的就需要用getSession自己写


主流技术到底就是主流技术,效率就不一般。

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

原来b/s架构的大量数据库操作可以这么轻松搞定。

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 implementation of the
Clinic interface.

*

* <p>The mappings are defined in
"petclinic.hbm.xml",

* located in the root of the classpath.

*

*
@author Juergen Hoeller

* @since 19.10.2003

*/

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

}

}

这方法getHibernateTemplate
()
是什么意思啊?

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):设置分页的大小

*********************************************

在前一篇日志中自动生成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 ;

}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐