Springboot Mybatis使用PageHelper实现分页查询

秒速五厘米 2023-10-02 15:09 87阅读 0赞

以下介绍实战中数据库框架使用的是mybatis,对整合mybatis此处不做介绍。

使用pageHelper实现分页查询其实非常简单,共两步:

一、导入依赖;

pom.xml添加依赖:

  1. <!--分页插件 pagehelper -->
  2. <dependency>
  3. <groupId>com.github.pagehelper</groupId>
  4. <artifactId>pagehelper-spring-boot-starter</artifactId>
  5. <!-- 特别注意版本问题 -->
  6. <version>1.2.3</version>
  7. </dependency>

二、添加配置;

aplication.yml添加配置:

  1. #分页pageHelper
  2. pagehelper:
  3. helper-dialect: mysql
  4. reasonable: true
  5. 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 配置的字段中取值,查找到合适的值时就会自动分页。

至此已经可以使用pageHelper

  1. @Override
  2. public List<User> findAllUserByPageF(int pageNum, int pageSize) {
  3. // TODO Auto-generated method stub
  4. PageHelper.startPage(pageNum, pageSize);
  5. List<User> lists = userMapper.queryUserInfo();
  6. return lists;
  7. }
  8. @Override
  9. public PageInfo<User> findAllUserByPageS(int pageNum, int pageSize) {
  10. // TODO Auto-generated method stub
  11. PageHelper.startPage(pageNum, pageSize);
  12. List<User> lists = userMapper.queryUserInfo();
  13. PageInfo<User> pageInfo = new PageInfo<User>(lists);
  14. return pageInfo;
  15. }

自动的对PageHelper.startPage 方法下的第一个sql 查询进行分页

发表评论

表情:
评论列表 (有 0 条评论,87人围观)

还没有评论,来说两句吧...

相关阅读