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