Java纯后台分页

常见的分页场景大多是网页上的分页,点一次请求分页查询一次。有时候可能需求:后台一次请求查询多次分页:
实现方式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;
}

猜你喜欢

转载自blog.csdn.net/u010509052/article/details/79790769