首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 软件管理 > 软件架构设计 >

对于Hibernate callback()的了解

2012-08-22 
对于Hibernate callback()的理解HibernateTemplate提供了非常多的常用方法来完成数据库的基本操作,使得持

对于Hibernate callback()的理解

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执行的持久化操作。
???????? 做分页:
public List findByPage(final String hql,
??????? final int offset, final int pageSize)
??? {
??????? //通过一个HibernateCallback对象来执行查询
??????? List list = getHibernateTemplate()
??????????? .executeFind(new HibernateCallback()
??????? {
??????????? //实现HibernateCallback接口必须实现的方法
??????????? public Object doInHibernate(Session session)
??????????????? throws HibernateException, SQLException
??????????? {
??????????????? //执行Hibernate分页查询
??????????????? List result = session.createQuery(hql)
??????????????????? .setFirstResult(offset)
??????????????????? .setMaxResults(pageSize)
??????????????????? .list();
??????????????? return result;
??????????? }
??????? });
??????? return list;
??? }

??? /**
??? * 使用hql语句进行分页查询
??? * @param hql 需要查询的hql语句
??? * @param value 如果hql有一个参数需要传入,value就是传入hql语句的参数
??? * @param offset 第一条记录索引
??? * @param pageSize 每页需要显示的记录数
??? * @return 当前页的所有记录
??? */
??? public List findByPage(final String hql , final Object value ,
??????? final int offset, final int pageSize)
??? {
??????? //通过一个HibernateCallback对象来执行查询
??????? List list = getHibernateTemplate()
??????????? .executeFind(new HibernateCallback()
??????? {
??????????? //实现HibernateCallback接口必须实现的方法
??????????? public Object doInHibernate(Session session)
??????????????? throws HibernateException, SQLException
??????????? {
??????????????? //执行Hibernate分页查询
??????????????? List result = session.createQuery(hql)
??????????????????? //为hql语句传入参数
??????????????????? .setParameter(0, value)
??????????????????? .setFirstResult(offset)
??????????????????? .setMaxResults(pageSize)
??????????????????? .list();
??????????????? return result;
??????????? }
??????? });
??????? return list;
??? }

??? /**
??? * 使用hql语句进行分页查询
??? * @param hql 需要查询的hql语句
??? * @param values 如果hql有多个个参数需要传入,values就是传入hql的参数数组
??? * @param offset 第一条记录索引
??? * @param pageSize 每页需要显示的记录数
??? * @return 当前页的所有记录
??? */
??? public List findByPage(final String hql, final Object[] values,
??????? final int offset, final int pageSize)
??? {
??????? //通过一个HibernateCallback对象来执行查询
??????? List list = getHibernateTemplate()
??????????? .executeFind(new HibernateCallback()
??????? {
??????????? //实现HibernateCallback接口必须实现的方法
??????????? public Object doInHibernate(Session session)
??????????????? throws HibernateException, SQLException
??????????? {
??????????????? //执行Hibernate分页查询
??????????????? Query query = session.createQuery(hql);
??????????????? //为hql语句传入参数
??????????????? for (int i = 0 ; i < values.length ; i++)
??????????????? {
??????????????????? query.setParameter( i, values[i]);
??????????????? }
??????????????? List result = query.setFirstResult(offset)
??????????????????? .setMaxResults(pageSize)
??????????????????? .list();
??????????????? return result;
??????????? }
??????? });
??????? return list;
??? }
}

?

本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/J2EEWEIWEI/archive/2009/08/01/4399671.aspx

热点排行