分页

package com.baiyue.redPackets.entity;

import lombok.Data;

import java.util.List;

@Data
public class Page<T> {

    //已知数据
    private int pageNum;    //当前页,从请求那边传过来。
    private int pageSize;    //每页显示的数据条数。
    private int totalRecord;    //总的记录条数。查询数据库得到的数据

    //需要计算得来
    private int totalPage;    //总页数,通过totalRecord和pageSize计算可以得来
    //开始索引,也就是我们在数据库中要从第几行数据开始拿,有了startIndex和pageSize,
    //就知道了limit语句的两个数据,就能获得每页需要显示的数据了
    private int startIndex;


    //将每页要显示的数据放在list集合中
    private List<T> list;

    //分页显示的页数,比如在页面上显示1,2,3,4,5页,start就为1,end就为5,这个也是算过来的
    private int start;
    private int end;

    //通过pageNum,pageSize,totalRecord计算得来tatalPage和startIndex
    //构造方法中将pageNum,pageSize,totalRecord获得
    public Page(int pageNum, int pageSize, int totalRecord) {
        this.pageNum = pageNum;
        this.pageSize = pageSize;
        this.totalRecord = totalRecord;

        //totalPage 总页数
        if (totalRecord % pageSize == 0) {
            //说明整除,正好每页显示pageSize条数据,没有多余一页要显示少于pageSize条数据的
            this.totalPage = totalRecord / pageSize;
        } else {
            //不整除,就要在加一页,来显示多余的数据。
            this.totalPage = totalRecord / pageSize + 1;
        }
        //开始索引
        this.startIndex = (pageNum - 1) * pageSize;
        //显示5页,这里自己可以设置,想显示几页就自己通过下面算法修改
        this.start = 1;
        this.end = 5;
        //显示页数的算法

        if (totalPage <= 5) {
            //总页数都小于5,那么end就为总页数的值了。
            this.end = this.totalPage;
        } else {
            //总页数大于5,那么就要根据当前是第几页,来判断start和end为多少了,
            this.start = pageNum - 2;
            this.end = pageNum + 2;

            if (start < 0) {
                //比如当前页是第1页,或者第2页,那么就不如和这个规则,
                this.start = 1;
                this.end = 5;
            }
            if (end > this.totalPage) {
                //比如当前页是倒数第2页或者最后一页,也同样不符合上面这个规则
                this.end = totalPage;
                this.start = end - 5;
            }
        }
    }
}
@Override
public Map<String, Object> queryHistoryRecord(String ln, String type, Integer pageNum) {
    // 获取当前时间时间戳
    String startTime = "";
    String endTime = "";

    Calendar cal=Calendar.getInstance();
    String date = new SimpleDateFormat("yyyy-MM-dd").format(cal.getTime());
    // 查询当天的历史记录
    if ("1".equals(type)){
        startTime = date + " 00:00:00";
        endTime = date + " 23:59:59";
    }else if ("2".equals(type)){
        // 查询昨天历史记录
        cal.add(Calendar.DATE,-1);
        Date time=cal.getTime();
        String yesterday = new SimpleDateFormat("yyyy-MM-dd").format(time);
        startTime = yesterday + " 00:00:00";
        endTime = yesterday + " 23:59:59";
    }else if ("3".equals(type)){
        // 查询昨天历史记录
        cal.add(Calendar.DATE,-2);
        Date time=cal.getTime();
        String beforeYesterday = new SimpleDateFormat("yyyy-MM-dd").format(time);
        startTime = beforeYesterday + " 00:00:00";
        endTime = beforeYesterday + " 23:59:59";
    }else {
        // 查询昨天历史记录
        cal.add(Calendar.DATE,-7);
        Date time=cal.getTime();
        String beforeWeek = new SimpleDateFormat("yyyy-MM-dd").format(time);
        startTime = beforeWeek + " 00:00:00";
        endTime = beforeWeek + " 23:59:59";
    }


    // 查询所有记录
    List<BureauUserDto> allBureauUsers = bureauUserMapper.findAllList();

    // 设置总记录条数
    int totalRecord = allBureauUsers.size();

    // 每页记录条数
    int pageSize = 20;

    Page page = new Page(pageNum, pageSize, totalRecord);

    int startIndex = page.getStartIndex();
    Map<String, Object> maps = new HashMap<>();
    maps.put("totalPage",page.getTotalPage());
    maps.put("pageList", bureauUserMapper.findAll(startIndex, pageSize, ln));
    return maps;
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值