Spring+Hibernate实现的DAO层公共类 - 编程入门网
作者 佚名技术
来源 NET编程
浏览
发布时间 2012-06-21
getHibernateTemplate().find(hql, params);
return list;
}
/** *//**
* 按HQL分页查询
* @param firstResult 开始记录号
* @param maxResults 最大记录数
* @param hql 查询语句,支持连接查询和多条件查询
* @param params 参数数组,代替餐hql中的"?"号
* @return 封装List和total的Pager对象
*/
@SuppressWarnings("unchecked")
public Pager<T> findForPagerByHql(final int firstResult, final int maxResults, final String hql, final Object params){
Pager<T> pager = (Pager<T>)getHibernateTemplate().execute(new HibernateCallback(){
public Object doInHibernate(Session session)
throws HibernateException, SQLException {
Query query = session.createQuery(hql);
for(int position = 0; position < params.length; position ++){
query.setParameter(position, params[position]);
}
int totalCounts = query.list().size(); //总记录数
//用于分页查询
if(maxResults > 0){
query.setFirstResult(firstResult);
query.setMaxResults(maxResults);
}
List<T> list = query.list();
Pager<T> pager = new Pager<T>();
pager.setEntityList(list);
pager.setTotalCounts(totalCounts);
return pager;
}
});
return pager;
}
}
文章来源:http://www.blogjava.net/rongxh7 |
凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢! |
你可能对下面的文章感兴趣
关于Spring+Hibernate实现的DAO层公共类 - 编程入门网的所有评论