**
* 使用hql 语句进行操作
* @param hql
* @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;
}/**
* 使用criterion进行操作
* @param arg
* @param criterions
* @param offset
* @param length
* @return List
*/
protected List getListForPage(final Class arg, final Criterion[] criterions,final int offset, final int length) {
List list = getHibernateTemplate().executeFind(new HibernateCallback() {
public Object doInHibernate(Session session)
throws HibernateException, SQLException {
Criteria criteria = session.createCriteria(arg);
//循环遍历添加约束条件
for (int i = 0; i < criterions.length; i++) {
criteria.add(criterions[i]);
}
criteria.setFirstResult(offset);
criteria.setMaxResults(length);
return criteria.list();
}
});
return list;
}
你不是说你用HibernateTemplate了,如果你用的是spring的HibernateTemplate,那么就直接用就行了,如果你是自己写的template,
那你也应该会准备一个HibernateCallback类啊,这才是典型的模板加回调啊
算了,把HibernateCallback也给你贴出来
import org.hibernate.HibernateException;
import org.hibernate.Session;
/*************************************
* 为 Hibernate 所提供的一个 回调接口,
* 此接口定义了 统一 Hibernate的业务操作;
* @author kenshin
*
*/
public interface HibernateCallback {
/**************************************
* 回调接口的回调方法,此方法使用者无需调用,
* 它由 模板类来进行回调,并传入一个 session参数,
* 以便让使用者完成相关业务
* @param ses
* @return 执行结果
* @throws HibernateException
*/
Object doInHibernate(Session ses)
throws HibernateException;
}