select * from t_notice_info tni order by create_time desc limit ? limit ?,?
项目里面同时使用了 PageHelper 和 mybatis plus 的 page 方法,但是在一次查询中只使用了 mybatis plus 的分页查询,结果出现了上面的问题,目前我知道主要是 PageInterceptor 拦截器错误识别对象导致的,但是我本地没办法复现问题,有哪位遇到过,可以解释一下吗
1
Vcccc 2023-06-30 14:15:27 +08:00
如果是 springboot 项目,可以试试加一个 HandlerInterceptor ,然后再清空 PageHelper 的参数。原因大概是上一个查询报错了,然后当前线程保留了上一个分页参数,这里的做法就是,请求结束后,都做一次清空分页参数。
public class PageHelperInterceptor implements HandlerInterceptor { @Override public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception { PageHelper.clearPage(); } } @Configuration public class WebConfigurer implements WebMvcConfigurer { @Override public void addInterceptors(InterceptorRegistry registry) { registry.addInterceptor(new PageHelperInterceptor()).addPathPatterns("/**"); } } |
2
fantaxi 2023-06-30 14:51:55 +08:00
是不是参数没清空导致的,每次查询完我都 PageHelper.clearPage() 一下
|
4
jwh199588 OP @fantaxi 我奇怪的点就是我这个方法里面并没有用到 PageHelper ,用的是 mybatis plus 的 page 方法
|
5
Laysan 2023-06-30 15:29:30 +08:00
干掉 PageHelper
|
6
zzzmh 2023-06-30 15:31:39 +08:00
不用 PageHelper ,就用 mybatisplus 自带的分页就行,可以自己写个工具类去辅助下,比如优化一下返回值。
|
7
SilentRhythm 2023-06-30 15:38:29 +08:00
PageHelper 是 Thread 级别的拦截器,然后线程是复用的,实际上是线程泄露导致。
同一条线程只要调用了 PageHelper.startPage()没有紧跟.doSelectPageInfo()就会导致上述这种不明所以的拦截。 建议排查整个项目的 PageHelper.startPage(pageNum, pageSize)调用, 然后改成紧跟 lambda 的写法 PageHelper.startPage(pageNum, pageSize).doSelectPageInfo(() -> 实现) |
8
SilentRhythm 2023-06-30 15:46:36 +08:00
|
9
SilentRhythm 2023-06-30 15:46:56 +08:00
接上,建议参考源码:
com.github.pagehelper.page.PageMethod#startPage com.github.pagehelper.page.PageMethod#setLocalPage com.github.pagehelper.PageInterceptor#intercept com.github.pagehelper.PageHelper#afterAll |
10
Vcccc 2023-06-30 17:21:31 +08:00
@jwh199588 如果单独看日志来定位错误的点是有很大局限性的。看看 #7 给你的回复,回答的还算是比较详细,并且跟我认为错误的点很契合
|
11
RainCats 2023-06-30 17:23:00 +08:00
没遇到过这个问题
|
12
crazykk 2023-06-30 17:25:48 +08:00
是的,我记得 github 上有作者提到这种错误,要紧跟查询,同 7 楼的说法
|
13
janwarlen 2023-06-30 18:16:04 +08:00
try (Page<T> p = PageHelper.startPage(pageNo, pageSize)) {
} |
14
curvatureship 2023-06-30 18:22:09 +08:00
有可能是依赖版本的问题,PageHelper 和 MybatisPlus 分页共存遇到过类似的问题,查看错误日志排查后是因为 PageHelper 和 MybatisPlus 共同依赖的 jsqlparder 版本不一致导致的,调整版本后两者能共存没问题
|