spring boot 中分页插件PageHelper的使用

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

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

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

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

一.pom文件里添加依赖

添加如下依赖即可:

    
        <dependency>
            <groupId>com.github.pagehelpergroupId>
            <artifactId>pagehelper-spring-boot-starterartifactId>
            <version>1.1.2version>
        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 pageSensitiveWords = sensitiveWordMapper.selectPageByWord(currentPage,pageSize,sensitiveWord);
//将查询结果封装成PageInfo返回给前端,里面包含当前页等很多分页相关信息
PageInfo pageInfo = new PageInfo(pageSensitiveWords);

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

ORDER BY update_time DESC,ID DESC

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

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

你可能感兴趣的:(springboot,Spring,Boot)