spring boot 中分页插件PageHelper的使用

PageHelper做的是什么呢?它封装了分页的后台部分,将你的语句改装成了一个分页查询的sql。它的优缺点:

优点:封装分页sql,使我们不需要每个地方都去写分页的查询语句;同时,使我们select的sql语句向下兼容,换了数据库也不需要更改sql代码;

缺点:自带的Page对象转json时会丢失分页数据;而转为PageInfo对象时分页信息过多(这一点作者已在github上说明,建议自己实现PageInfo)

至于使用方面,在spring boot中是比较简单的,如下:

一.pom文件里添加依赖

添加如下依赖即可:

    <!-- 分页插件 -->
        <dependency>
            <groupId>com.github.pagehelper</groupId>
            <artifactId>pagehelper-spring-boot-starter</artifactId>
            <version>1.1.2</version>
        </dependency>

二.项目配置文件application.properties里加配置项

#pagehelper分页插件
#指定用的什么数据库
pagehelper.helperDialect=mysql
#分页合理化参数,默认值为false。当该参数设置为 true 时,
#pageNum<=0 时会查询第一页
pagehelper.reasonable=true
#支持通过 Mapper 接口参数来传递分页参数,默认值false
pagehelper.supportMethodsArguments=true
pagehelper.params.count=countSql

三.项目代码里开始使用

//currentPage当前页数,pageSize为每页数据条数
PageHelper.startPage(currentPage, pageSize);
//SensitiveWord为数据实体,sensitiveWord为sql里自己传入的查询变量
//selectPageByWord()就是自己正常的dao层方法
Page<SensitiveWord> pageSensitiveWords = sensitiveWordMapper.selectPageByWord(currentPage,pageSize,sensitiveWord);
//将查询结果封装成PageInfo返回给前端,里面包含当前页等很多分页相关信息
PageInfo<SensitiveWord> pageInfo = new PageInfo<SensitiveWord>(pageSensitiveWords);

值得一提一个问题是:分页查询临近页部分数据重复问题
这是因为排序未做到唯一排序导致的,可通过对主键唯一排序解决,例如先对时间排序,后面再对主键排序,这样就可以做到唯一排序了。
也就是在查询语句后面加上类似这样的排序写法:

ORDER BY update_time DESC,ID DESC

至此,就是使用的完整过程了。然后贴一下参考之处,想深入了解,可多看大佬的文档,里面很详尽:

Mybatis-PageHelper开源大佬写的使用文档

  • 2
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值