hql分页( HibernateCallback接口 )

来源:互联网 发布:python sha.new 编辑:程序博客网 时间:2024/04/29 22:46


//==>July22 更新一个带分页的

/*** 使用hql 语句进行操作 * @param hql HSQL 查询语句 * @param offset 开始取数据的下标 * @param length 读取数据记录数 * @return List 结果集 */ public List findListByPage(final String hql, final int firstResult, final int length)throws Exception { List list = hibernateTemplate.executeFind(new HibernateCallback() { public Object doInHibernate(Session session) throws HibernateException, SQLException {Query query = session.createQuery(hql); query.setFirstResult(firstResult); query.setMaxResults(length); List list = query.list(); return list;}}); return list;}
//==>July22 更新一个带分页的




public List<Object> querySQL(final String hql,final Class entityClass){try{return this.getHibernateTemplate().execute(new HibernateCallback<List<Object>>() {@Overridepublic List<Object> doInHibernate(Session session)throws HibernateException, SQLException {Query query=session.createSQLQuery(hql).addEntity(entityClass);return query.list();}});}catch(RuntimeException re) {throw re;}}


    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执行的持久化操作。     还有的就是采用:   HibernateTemplate.execute(HibernateCallback action)这种回调的方式,封装了对异常的处理和对事务的一些处理。



原创粉丝点击