1、收先写个分页的bean用来保存查询到的数据
package utils;
import java.util.List;
public class PageBean<T> {
private int page; // 当前页数
private int totalCount; // 总记录数
private int totalPage; // 总页数
private int limit; // 每页显示的记录数
private List<T> list; // 每页显示数据的集合.
public int getPage() {
return page;
}
public void setPage(int page) {
this.page = page;
}
public int getTotalCount() {
return totalCount;
}
public void setTotalCount(int totalCount) {
this.totalCount = totalCount;
}
public int getTotalPage() {
return totalPage;
}
public void setTotalPage(int totalPage) {
this.totalPage = totalPage;
}
public int getLimit() {
return limit;
}
public void setLimit(int limit) {
this.limit = limit;
}
public List<T> getList() {
return list;
}
public void setList(List<T> list) {
this.list = list;
}
}
2、因为this.getHibernateTemplate()提供的方法不足以让我们去完成分页(单表能行,我记得findByCriteria,findByExample可以进行分页查询)
这个是单表的不过我自己没试过
【DetachedCriteria来构造查询条件,参数需要查询的类
List l1=this.getHibernateTemplate().findByCriteria(DetachedCriteria.forClass(类CLASS), 开始记录 , 每页显示记录数);
应用实例查询
List l2=this.getHibernateTemplate().findByExample(new 类, 开始记录 , 每页显示记录数);
】
回归正题:既然提供的直接方法不足以那就用间接的:
<List<Object>> List<Object> org.springframework.orm.hibernate3.HibernateTemplate.execute(HibernateCallback<List<Object>> action) throws DataAccessException
这个是在dao层的写法
1、public List<Xsb> findAll(int first,int max){
String hql="from po.Xsb";
List<Xsb> list=this.getHibernateTemplate().execute(
new PageHibernateCallback<>(hql, null, first, max)
);
return list;
}
2、public List findAll(int first,int max){
String hql="select a.xm,b.kcm,c.id.xh,c.cj,c.xf,c.id.kch from po.Xsb a"
+ ",po.Kcb b,po.Cjb c where a.xh=c.id.xh and b.kch=c.id.kch ";
List list=this.getHibernateTemplate().execute(
new PageHibernateCallback<>(hql, null, first, max)
);
return list;
}
使用这个方法要写一个匿名内部类去实现HibernateCallback这个接口的方法或者直接写个工具类去实现接口)我是写工具类PageHibernateCallback啦【直接上代码】
package utils;
import java.sql.SQLException;
import java.util.List;
import org.hibernate.HibernateException;
import org.hibernate.Query;
import org.hibernate.Session;
import org.springframework.orm.hibernate3.HibernateCallback;
public class PageHibernateCallback<T> implements HibernateCallback<List<T>>{//这里使用T来指定某一类型
private String hql;
private Object[] params;//参数数组
private int startIndex;
private int pageSize;
public PageHibernateCallback(String hql, Object[] params,
int startIndex, int pageSize) {
super();
this.hql = hql;
this.params = params;
this.startIndex = startIndex;
this.pageSize = pageSize;
}
public List<T> doInHibernate(Session session) throws HibernateException,
SQLException {
//1要 执行hql语句的实例
Query query = session.createQuery(hql);
//2 实际参数
if(params != null){
for(int i = 0 ; i < params.length ; i ++){
query.setParameter(i, params[i]);
}
}
//3 分页
query.setFirstResult(startIndex);
query.setMaxResults(pageSize);
return query.list();
}
}
然后是servers层的:
2、public PageBean<Object> findAll(int page){
int limit=5,totalPage=0;
int first=(page-1)*limit;
int totalCount=cjbDao.findNum().intValue();
if(totalCount % limit == 0){
totalPage = totalCount / limit;
}else{
totalPage = totalCount / limit + 1;
}
List list=cjbDao.findAll(first, limit);
PageBean<Object> bean=new PageBean<>();
bean.setTotalCount(totalCount);
bean.setList(list);
bean.setLimit(limit);
bean.setPage(page);
bean.setTotalPage(totalPage);
return bean;
}
-----------------------------
1、public PageBean<Xsb> findAll(int page){
int limit=5,totalPage=0;
int first=(page-1)*limit;
int totalCount=xsbDao.findNum().intValue();
if(totalCount % limit == 0){
totalPage = totalCount / limit;
}else{
totalPage = totalCount / limit + 1;
}
List<Xsb> list=xsbDao.findAll(first, limit);
PageBean<Xsb> bean=new PageBean<>();
bean.setTotalCount(totalCount);
bean.setList(list);
bean.setLimit(limit);
bean.setPage(page);
bean.setTotalPage(totalPage);
return bean;
}
这样就完成了
题外话:想想我以前第一次写分页,我当时是把所有的数据都弄到前端然后用jq去隐藏显示(当时也是无知者无畏也^v^)