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;
}
  • 5
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值