第一步:
pom.xml添加依赖:
com.github.pagehelper
pagehelper-spring-boot-starter
1.2.3
第二步:
aplication.yml添加配置:
#分页pageHelper
pagehelper:
helper-dialect: mysql
reasonable: true
support-methods-arguments: true
·helper-dialect:
配置使用哪种数据库语言,不配置的话pageHelper也会自动检测
·reasonable:
配置分页参数合理化功能,默认是false。 #启用合理化时,如果pageNum<1会查询第一页,如果pageNum>总页数会查询最后一页; #禁用合理化时,如果pageNum<1或pageNum>总页数会返回空数据。
·params:
为了支持startPage(Object params)方法,增加了该参数来配置参数映射,用于从对象中根据属性名取值; 可以配置 pageNum,pageSize,count,pageSizeZero,reasonable,不配置映射的用默认值, 默认值为pageNum=pageNum;pageSize=pageSize;count=countSql;reasonable=reasonable;pageSizeZero=pageSizeZero。
·support-methods-arguments:
支持通过Mapper接口参数来传递分页参数,默认值false,分页插件会从查询方法的参数值中,自动根据上面 params 配置的字段中取值,查找到合适的值时就会自动分页。
mapper层写上查询该表数据返回List的方法:
/**
* Created by 柱子 on 2020/9/25 19:47 分页查询测试
*/
@Mapper
@Repository
public interface StudentMapper {
//查询所有
@Select("select * from student")
List queryUserInfo();
}
在service以及impl也写上相关方法:
//查询所有
List queryUserInfo();
Impl实现类
@Override
//分页查询
public List queryUserInfo() {
return userMapper.queryUserInfo();
接下来开始使用分页插件,配合上面的查询实现分页查询在userService上添加 分页查询方法2个
List findAllUserByPageF(int pageNum,int pageSize);
PageInfo findAllUserByPageS(int pageNum, int pageSize);
@Override
public List findAllUserByPageF(int pageNum, int pageSize) {
// TODO Auto-generated method stub
PageHelper.startPage(pageNum, pageSize);
List lists = studentMapper.queryUserInfo();
return lists;
}
@Override
public PageInfo findAllUserByPageS(int pageNum, int pageSize) {
// TODO Auto-generated method stub
PageHelper.startPage(pageNum, pageSize);
List lists = studentMapper.queryUserInfo();
PageInfo pageInfo = new PageInfo(lists);
return pageInfo;
}
最后在controller写上测试接口
@GetMapping("/testPageHelper1")
public PageInfo testPageHelper1(){
PageInfo queryResult = studentService.findAllUserByPageS(1, 5);
return queryResult;
}
@GetMapping("/testPageHelper2")
public List testPageHelper2(){
List queryResult = studentService.findAllUserByPageF(1, 5);
return queryResult;
}
使用了分页插件返回的结果数据:
{
"pageNum":1, //当前页码
"pageSize":50, //每页个数
"size":1, //当前页个数
"startRow":1, //由第几条开始
"endRow":1, //到第几条结束
"total":1, //总条数
"pages":1, //总页数
"list":[{"dateTime":"2020-03-21","operationType":1}],//查出出来的数据集合
"prePage":0, //上一页
"nextPage":0, //下一页
"isFirstPage":true, //是否为首页
"isLastPage":true, //是否为尾页
"hasPreviousPage":false, //是否有上一页
"hasNextPage":false, //是否有下一页
"navigatePages":8, //每页显示的页码个数
"navigatepageNums":[1], //首页
"navigateFirstPage":1, //尾页
"navigateLastPage":1, //页码数
"firstPage":1,
"lastPage":1
}
https://blog.csdn.net/qq_35387940/article/details/91530234?utm_medium=distribute.pc_relevant.none-task-blog-BlogCommend