当前位置:   article > 正文

Springboot集成pagehelper 分页插件_springboot集成pagehelper分页插件

springboot集成pagehelper分页插件

引入依赖

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

application.yml配置

# PageHelper分页插件
pagehelper:
  helperDialect: mysql
  supportMethodsArguments: true
  params: count=countSql

controller

/**
 *  查询全部用户
 * @param pageNo        当前页
 * @param pageSize      条数
 * @param people
 * @return
 */
@GetMapping("/selectAll")
public List<People> selectAll( @RequestParam(defaultValue = "1") int pageNo, @RequestParam(defaultValue = "10") int pageSize,People people) {
    //接收前端传送的当前页和总条数,放入PageHelper当中,如果没有就取默认值 1和10
     PageHelper.startPage(pageNo,pageSize);
    return peopleService.selectAll(people);
}

结果:

日志打印

通过日志执行的sql语句我们可以看出,这里的10是取的默认值10,等于第一页,10条数据

模拟前端传入pageNo=1和pageSize  =2   表示第1页,2条数据

结果:

日志打印

通过执行的sql语句可以看出查询的条数为2条

坑:

这个坑叫做可能会出现,也可能不会出现,启动报错,叫做:  依赖循环

Relying upon circular references is discouraged and they are prohibited by default. Update your application to remove the dependency cycle between beans. As a last resort, it may be possible to break the cycle automatically by setting spring.main.allow-circular-references to true.

翻译:

不鼓励依赖循环引用,默认情况下禁止使用循环引用。更新应用程序以消除bean之间的依赖循环。作为最后手段,通过设置弹簧,可能会自动中断循环。主要的允许循环引用true。

依赖循环:

        详见:Spring面试之循环依赖(allowCircularReferences)_退休职工的博客-CSDN博客

导致原因:

我们打开maven库,找到 com---github---pagehelper---pagehelper-spring-boot-starter

找到对应的版本1.4.1,解压pagehelper-spring-boot-starter-1.4.1.jar包,

解压后打开META-INF文件,打开最里面的pom.xml,发现这个pom文件中引入了这些文件,发现与我们之前引入的依赖进行冲突了

解决方案:

1、修改yml配置

spring:
  main:
   allow-circular-references: true

2.解决冲突。修改spring的版本

将版本改为2.5.7,也可以正常启动

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/凡人多烦事01/article/detail/88123
推荐阅读
相关标签
  

闽ICP备14008679号