浏览 2600 次
精华帖 (0) :: 良好帖 (0) :: 新手帖 (0) :: 隐藏帖 (0)
|
|
---|---|
作者 | 正文 |
发表时间:2008-12-10
最后修改:2008-12-10
public class HibernateTemplate extends HibernateAccessor implements HibernateOperations { ... } 继承HibernateAccessor,我们再来看看HibernateAccessor,HibernateAccessor里最重要的就是设置SessionFactory 再看HibernateOperations接口,HibernateOperations里定义了我们常用的get(...)、find(...)、save(...)等操作, 其中最重要的就是Object execute(HibernateCallback action) throws DataAccessException; 现在我们又多了一个接口:HibernateCallback,HibernateCallback回调接口,它里面只有一个方法的定义, Object doInHibernate(Session session) throws HibernateException, SQLException; 基本上相关联的比较重要的东东我们提到了。 接下来我们来看看HibernateTemplate的实现 通常我们写数据库操作时都如下: -------------------------------------- /** 插入一个Info对象 */ public void insertInfo(Info info) { this.getHibernateTemplate().save(info); } /** 分页查询Info表 */ public List queryInfoList(int pageSize, int startRow) { final int pageSize1 = pageSize; final int startRow1 = startRow; return this.getHibernateTemplate().executeFind(new HibernateCallback(){ public List doInHibernate(Session session) throws HibernateException, SQLException { Query query = session.createQuery(FIND_ALL_INFO); query.setFirstResult(startRow1); query.setMaxResults(pageSize1); return query.list(); } }); } 这里面到底发生了什么事情呢?看看HibernateTemplate中的execute(...)的实现 (注:为了简单起见,先抛出事务什么的...) --------------------------------------- public Object execute(HibernateCallback action) throws DataAccessException { 先通过SessionFactory获取到Hibernate的Session对象 执行HibernateCallback的对象的doInHibernate(...)的方法 看看上面我们的“分页查询Info表”的方法 关闭Session 返回查询结果 } HibernateTemplate中的get(...)、find(...)、save(...)等方法,只不过是spring事先为我们实现了 HibernateCallback接口而已 ----------------------------------------- HibernateTemplate就如同它的名字一样,运用了模板方法的模式,只是spring的运用方式实现是高明!佩服! 景仰! 声明:ITeye文章版权属于作者,受法律保护。没有作者书面许可不得转载。
推荐链接
|
|
返回顶楼 | |
发表时间:2008-12-10
最后修改:2008-12-10
就是一个回调接口。方便事物的统一管理。
|
|
返回顶楼 | |