关闭

Hibernate的复杂用法HibernateCallback

518人阅读 评论(0) 收藏 举报
分类:

HibernateTemplate提供了非常多的常用方法来完成数据库的基本操作,使得持久层访问摸板化,只要创建HibernateTemplate 实例后,注入一个SessionFactory的引用就可以了.无须手动创建sessionFactory,更加智能的管理Hibernate 的Session,没有大量的try/catch操作,

void delete(Object entity)删除指定持久化实例

deleteAll(Collection entities)删除集合内全部持久化实例

find(String queryString)根据HQL查询字符串返回实例集合

findByNamedQuery(Striing QueryName)根据命名查询返回实例集合

Get(Class entityClass,Serializable id)割据主键加载特定持久化类的实例

save(Object entity)保存实例 saveOrUpdate(Object entity)

根据实例状态,选择保存或者更新 update(Object entity)更新实例的状态

setMaxResults(int maxResults)设置分页大小

Hibernate的复杂用法HibernateCallback ,HibernateTemplate还提供一种更加灵活的方式来操作数据库,通过这种方式可以完全使用Hibernate的操作方式。

 HibernateTemplate的灵活访问方式是通过如下两个方法完成:

(1)Object execute(HibernateCallback action)

(2)List execute(HibernateCallback action)

这两个方法都需要一个HibernateCallback的实例,HibernateCallback实例可在任何有效的Hibernate数据访问中使用。 程序开发者通过HibernateCallback,可以完全使用Hibernate灵活的方式来访问数据库,解决Spring封装Hibernate后灵活性不足的缺陷。 HibernateCallback是一个接口,该接口只有一个方法doInHibernate(org.hibernate.Session session), 该方法只有一个参数Session。

通常,程序中采用实现HibernateCallback的匿名内部类来获取HibernateCallback的实例, 方法doInHibernate的方法体就是Spring执行的持久化操作。

 做分页:

[java] view plain copy
  1. public List findByPage(final String hql, final int offset, final int pageSize)   
  2.   
  3. //通过一个HibernateCallback对象来执行查询   
  4.   
  5. List list = getHibernateTemplate() .executeFind(new HibernateCallback() {   
  6.   
  7.    
  8.   
  9. //实现HibernateCallback接口必须实现的方法   
  10.   
  11. public Object doInHibernate(Session session) throws HibernateException, SQLException {  
  12.   
  13.  //执行Hibernate分页查询   
  14.   
  15. List result = session.createQuery(hql) .setFirstResult(offset) .setMaxResults(pageSize) .list(); return result;   
  16.   
  17. }   
  18.   
  19. });   
  20.   
  21. return list; }  
  22.   
  23.  /** * 使用hql语句进行分页查询 
  24.  
  25.  * @param hql 需要查询的hql语句 
  26.  
  27.  * @param value 如果hql有一个参数需要传入,value就是传入hql语句的参数  
  28.  
  29. * @param offset 第一条记录索引 * @param pageSize 每页需要显示的记录数  
  30.  
  31. * @return 当前页的所有记录 */   
  32.   
  33. public List findByPage(final String hql , final Object value , final int offset, final int pageSize)   
  34.   
  35. //通过一个HibernateCallback对象来执行查询   
  36.   
  37. List list = getHibernateTemplate() .executeFind(new HibernateCallback()   
  38.   
  39. {   
  40.   
  41. //实现HibernateCallback接口必须实现的方法  
  42.   
  43.  public Object doInHibernate(Session session) throws HibernateException, SQLException {  
  44.   
  45.  //执行Hibernate分页查询   
  46.   
  47. List result = session.createQuery(hql)  
  48.   
  49.  //为hql语句传入参数 .setParameter(0, value) .setFirstResult(offset) .setMaxResults(pageSize) .list();  
  50.   
  51.  return result;   
  52.   
  53. }   
  54.   
  55. });   
  56.   
  57. return list; }  
  58.   
  59.  /** * 使用hql语句进行分页查询  
  60.  
  61. * @param hql 需要查询的hql语句 
  62.  
  63.  * @param values 如果hql有多个个参数需要传入,values就是传入hql的参数数组  
  64.  
  65. * @param offset 第一条记录索引  
  66.  
  67. * @param pageSize 每页需要显示的记录数  
  68.  
  69. * @return 当前页的所有记录 */  
  70.   
  71.  public List findByPage(final String hql, final Object[] values, final int offset, final int pageSize) {  
  72.   
  73.  //通过一个HibernateCallback对象来执行查询   
  74.   
  75. List list = getHibernateTemplate() .executeFind(new HibernateCallback() {   
  76.   
  77. //实现HibernateCallback接口必须实现的方法  
  78.   
  79.  public Object doInHibernate(Session session) throws HibernateException, SQLException {   
  80.   
  81. //执行Hibernate分页查询   
  82.   
  83. Query query = session.createQuery(hql);   
  84.   
  85. //为hql语句传入参数   
  86.   
  87. for (int i = 0 ; i < values.length ; i++) {   
  88.   
  89. query.setParameter( i, values[i]); }  
  90.   
  91.  List result = query.setFirstResult(offset) .setMaxResults(pageSize) .list(); return result;   
  92.   
  93. }   
  94.   
  95. });   
  96.   
  97. return list;  
  98.   
  99.  }  
  100.   
  101.  }  

0
0
查看评论

HibernateCallback总结

HibernateCallback总结HibernateTemplate提供了非常多的常用方法来 完成数据库的基本操作,使得持久层访问模板化 。只要创建HibernateTemplate实例后,注入一 个SessionFactory的引用就可以了,而无需手动 创建sessionFactory,从而可...
  • lmb55
  • lmb55
  • 2016-07-19 08:40
  • 1068

Java回调机制以及使用HibernateCallBack()接口的好处

最近在做项目有太多的关于框架的
  • hyhy2203390
  • hyhy2203390
  • 2014-07-15 23:28
  • 1651

SSH整合后,HQL查询必须知道的内容,HibernateTemplate中实现分页

前言在之前笔者一直对于HQL查询是很不满意的,因为它不仅不能够实现分页查询,而且通过select attr1,attr2,attr3 from User,查询出来的还都是Object类型的,取值的时候非常不愉快。HQL有选择的的查询出对象类里面的值:第一种方式:我想大家都很熟悉下面这种查询方式,查询...
  • Marvel__Dead
  • Marvel__Dead
  • 2017-04-02 20:33
  • 3123

Hibernate的复杂用法HibernateCallback

<br />HibernateTemplate提供了非常多的常用方法来完成数据库的基本操作,使得持久层访问摸板化,只要创建HibernateTemplate 实例后,注入一个SessionFactory的引用就可以了.无须手动创建sessionFactory,更加智能的管理Hiberna...
  • kongjing0815
  • kongjing0815
  • 2011-05-30 10:19
  • 3299

HibernateCallback()详解

HibernateTemplate提供了非常多的常用方法来完成数据库的基本操作,使得持久层访问摸板化,只要创建HibernateTemplate 实例后,注入一个SessionFactory的引用就可以了.无须手动创建sessionFactory,更加智能的管理Hibernate 的Session,...
  • yaerfeng
  • yaerfeng
  • 2012-05-31 09:21
  • 9071

为什么要使用HibernateCallback

1.this.getSession() 是org.springframework.orm.hibernate3.support.HibernateDaoSupport 中的一个方法,它可以从当前事务或者一个新的事务获得一个hibernate session,需要程序维护session(手动关闭ses...
  • a6697238
  • a6697238
  • 2016-01-12 19:58
  • 1057

PageHibernateCallback

package com.zhlk.shop.util; import java.sql.SQLException; import java.util.List; import org.hibernate.HibernateException; import org.hibernate.Query;...
  • lvjinhan
  • lvjinhan
  • 2017-02-25 10:53
  • 494

一个简单的HibernateCallback接口的调用

interface HibernateCallback { public Object doInHibernate(Session session); } class Session { public Object createQuery(String hql) { Sys...
  • itpinpai
  • itpinpai
  • 2012-11-28 22:26
  • 1972

泛型Hibernate DAO实现基本操作

一个泛型hibernate DAO,用了spring的HibernateDaoSupport。提供基本的CRUD操作,支持分页查询,可使用HQL、Criteria和DetachedCriteria. [sql] view plain copy ...
  • laukicn
  • laukicn
  • 2017-05-26 16:03
  • 271

spring对hibernate的集成中的回调(CallBack)机制

回调函数对于我们来说并不陌生,之前我们在学习js的时候经常用到回调函数,在java基础中也接触到了回调函数,在这篇博客中我们将介绍spring和hibernate集成后的回调函数的使用。   为什么使用回调函数?      我们都知道程序员在完成CRUD...
  • u013045437
  • u013045437
  • 2017-02-02 20:33
  • 1134
    个人资料
    • 访问:184860次
    • 积分:2834
    • 等级:
    • 排名:第14879名
    • 原创:84篇
    • 转载:110篇
    • 译文:10篇
    • 评论:23条
    最新评论