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; }