mybatis plus 分页问题

2023-06-30 13:38:37 +08:00
 jwh199588
select * from t_notice_info tni order by create_time  desc limit ? limit ?,?

项目里面同时使用了 PageHelper 和 mybatis plus 的 page 方法,但是在一次查询中只使用了 mybatis plus 的分页查询,结果出现了上面的问题,目前我知道主要是 PageInterceptor 拦截器错误识别对象导致的,但是我本地没办法复现问题,有哪位遇到过,可以解释一下吗

1784 次点击
所在节点    程序员
14 条回复
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("/**");
}
}
fantaxi
2023-06-30 14:51:55 +08:00
是不是参数没清空导致的,每次查询完我都 PageHelper.clearPage() 一下
jwh199588
2023-06-30 14:55:27 +08:00
@Vcccc 根据你的意思,我看了一下代码,发现这个方法只分页查询了一次,没有其他查询了,应该不会触发呀
jwh199588
2023-06-30 15:10:46 +08:00
@fantaxi 我奇怪的点就是我这个方法里面并没有用到 PageHelper ,用的是 mybatis plus 的 page 方法
Laysan
2023-06-30 15:29:30 +08:00
干掉 PageHelper
zzzmh
2023-06-30 15:31:39 +08:00
不用 PageHelper ,就用 mybatisplus 自带的分页就行,可以自己写个工具类去辅助下,比如优化一下返回值。
SilentRhythm
2023-06-30 15:38:29 +08:00
PageHelper 是 Thread 级别的拦截器,然后线程是复用的,实际上是线程泄露导致。
同一条线程只要调用了 PageHelper.startPage()没有紧跟.doSelectPageInfo()就会导致上述这种不明所以的拦截。

建议排查整个项目的 PageHelper.startPage(pageNum, pageSize)调用,
然后改成紧跟 lambda 的写法
PageHelper.startPage(pageNum, pageSize).doSelectPageInfo(() -> 实现)
SilentRhythm
2023-06-30 15:46:36 +08:00
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
Vcccc
2023-06-30 17:21:31 +08:00
@jwh199588 如果单独看日志来定位错误的点是有很大局限性的。看看 #7 给你的回复,回答的还算是比较详细,并且跟我认为错误的点很契合
RainCats
2023-06-30 17:23:00 +08:00
没遇到过这个问题
crazykk
2023-06-30 17:25:48 +08:00
是的,我记得 github 上有作者提到这种错误,要紧跟查询,同 7 楼的说法
janwarlen
2023-06-30 18:16:04 +08:00
try (Page<T> p = PageHelper.startPage(pageNo, pageSize)) {

}
curvatureship
2023-06-30 18:22:09 +08:00
有可能是依赖版本的问题,PageHelper 和 MybatisPlus 分页共存遇到过类似的问题,查看错误日志排查后是因为 PageHelper 和 MybatisPlus 共同依赖的 jsqlparder 版本不一致导致的,调整版本后两者能共存没问题

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/952992

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX