Mybatis分页插件(PageHelper)数据量大时查询慢

问题描述:

在项目中使用Mybatis分页插件分页查询十分缓慢,但是在数据库中执行速度却很快?
该数据库的表共有三千万条数据,分页查询时,在数据库中是很快,但是在使用Mybatis分页插件的时候居然15s多!

原因:

PageHelper在做分页查询的时候,select count(0) from (业务sql) a 会先把业务sql语句全部重新查询一遍(未做数量限制),然后再执行select count(0)操作,相当于查询两遍,导致查询速度慢。

解决办法

5.0.4版本的Mybatis分页插件之后,支持了自定义Count方法来替换原来的Count方法
!](https://img-blog.csdnimg.cn/edb5c734d036441e9d16b2da039e1214.png)

注:getDeviceOrderInfo_COUNT()方法里面的sql自定义完成,尽量减少不必要的表关联,提高查询速率。

总结:

分页插件中的计算Count的sql语句,会将需要分页的所有数据查出来然后生成一个临时表,再去计算Count。如果数据量比较大,会导致最后Count计算会十分慢,从而影响分页的结果。

解决办法:
​ 覆盖原Count的sql(无需定义mapper接口),根据官方文档自定义。注意返回值类型(Long)与方法名(原名_COUNT)

  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值