关于Pagehelper分页失效不起作用的问题-与Feign有关
今天偶尔在项目里试pagehelper分页分页功能时,怎么都不会生效,不管怎么设置pageNum,pageSize都是将所有内容输出,在网上搜索了一些也没有效果,大多都是maven依赖引入有问题,但我的maven依赖已经设置为全局统一。
<dependency>
<groupId>com.github.pagehelper</groupId>
<artifactId>pagehelper-spring-boot-starter</artifactId>
<version>1.2.10</version>
</dependency>
项目整体结构是6个微服务组成,而我调试的商城微服务通过feign来调用其他微服务开放的接口,而恰恰是商城微服务上的分页不起作用,在确认不存在其他版本的pagehelper插件后,突然想到会不会是feign产生了影响。因为当前PageHelper是写在接口调用前的。
PageHelper.startPage(1,2);
List<App> apps = appService.getAppByCustomerId(customerId);
PageInfo pageInfo = new PageInfo<>(apps);
因为PageHelper方法使用了静态的ThreadLocal参数,分页参数和线程是绑定的。
只要你可以保证在PageHelper方法调用后紧跟 MyBatis 查询方法,这就是安全的。因为PageHelper在finally代码段中自动清除了ThreadLocal存储的对象。
如果代码在进入Executor前发生异常,就会导致线程不可用, 这种情况由于线程不可用,也不会导致ThreadLocal参数被错误的使用。
所以我先在其他被调用的微服务里测试了一下,就写在Mapper调用之前,PageHelper果然生效起作用了,可能是feign远程调用功能让PageHelper失效了,特记录在这里,这种情况比较特别,也比较傻,希望别有人犯。