**
* 使用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;
}