常见的分页场景大多是网页上的分页,点一次请求分页查询一次。有时候可能需求:后台一次请求查询多次分页:
实现方式1:
int start = 0;//开始记录索引位置
int pageSize = 100;//页大小(每页显示条数即一次查询多少条数据)
List<User> listDatas;
while ((listDatas = userDao.findPageData(parames, start, pageSize)) != null && listDatas.size() != 0){//读者自行实现分页查询
start = start + pageSize;//计算下次查询开始位置
for(User user:listDatas){
//自行处理查询出来的数据
}
}
实现方式2:和页面上分页类似
int pageSize = 100;
int pageNum = 1;//当前页码
int start = 0;
int totalRecord = userDao.findPageDataCount(parames);//查询总记录数读者自行实现
int pageCount = totalRecord%pageSize == 0 ? totalRecord/pageSize : totalRecord/pageSize + 1; //总页数(这个变量没用此处)
List<User> listDatas;
while((listDatas = userDao.findPageData(parames, start, pageSize)) != null && listDatas.size() != 0){
for(User user:listDatas){
//自行处理查询出来的数据
}
pageNum++;//下一页
start = (pageNum - 1)*pageSize;//通过当前页面算出开始记录索引
}
方式3:可和页面分页兼容
class Page<E>{
private List list; //分装分页数据
private int totalPage; //总页数
private int count; //总记录数
private int pageSize = 5; //页的大小
private int pageNum; //用户想看的页码
private int startIndex; //代表用户想看的页的数据从数据库哪个地方开始取
public Page(int count,int pageNum){
this.count = count;
this.pageNum = pageNum;
if((this.count%this.pageSize)==0){
this.totalPage = (this.count/this.pageSize);
}else{
this.totalPage = (this.count/this.pageSize) + 1;
}
this.startIndex = (this.pageNum-1)*this.pageSize;
}
}
int pageSize = 100;
int pageNum = 1;//当前页码
int totalRecord = userDao.findPageDataCount(parames);//查询总记录数读者自行实现
Page<User> page = new Page(pageNum,pageSize,totalRecord);
//===========如果 页面分页 将此部分代码注释即可=======
for(int i = 0;i<page.getPageCount();i++){
Page page = getPageData(params,page);// params参数自行组装
if(page.getList() != null && page.getList().size() !=0){
List data = page.getList();//自行处理查询出来的数据
}
}
//========================
public Page getPageData(params,page){
List<User> listDatas = userDao.findPageData(params, page.getStart(), page.getPageSize()));
page.setList(listDatas);
return page;
}
更多推荐
Java纯后台分页
发布评论