本文主要是介绍Mybatis分页插件(pagehelper)数据量稍大出现查询慢,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
Mybatis分页插件(pagehelper)数据量稍大出现查询慢 🐲 芜湖~
-
导入Springboot依赖
<!--分页插件--> <dependency><groupId>com.github.pagehelper</groupId><artifactId>pagehelper-spring-boot-starter</artifactId><version>1.3.0</version> </dependency>
-
编写Service层核心代码
@Overridepublic Page<Map<String, Object>> getDeviceOrderInfo(Map<String, Integer> map) {// 此处使用PageHelp去实现的话,会在大数据量的时候查询缓慢PageHelper.startPage(map.get("page"), map.get("limit"));Page<Dev> devInfo =devMapper.getInfo();return devInfo;}
-
编写mapper接口
/*** @author yeqian* @param* @return* @Description TODO * @Date 2021/5/25 15:41*/Page<Map<String, Object>> getInfo();
-
编写mapper.xml
<select id="getDeviceOrderInfo" resultType="map" useCache="true">SELECTname, age, genderFROM devInfo </select>
-
测试
优化查询速度🐷
⚠️在项目中使用Mybatis分页插件
分页查询十分缓慢,但是在数据库中执行速度却很快?
-
该数据库的表共有1000条数据,分页查询时,在数据库中是毫秒级别,但是在使用
Mybatis
分页插件的时候居然足足!!2s多
-
最后打印sql
💬无语,居然又查询了一遍,怪不得这么慢
select count(*) from ("这里面的把sql又多重复查了一遍") tab
-
解决办法💡
从5.0.4版本的Mybatis分页插件之后,支持了自定义Count方法来替换原来的Count方法
官方文档
实现步骤
-
首先在Mapper层定义一个Count方法
/*** @author yeqian* @param* @return* @Description TODO 查询所有的订单信息* @Date 2021/5/25 15:41*/ Page<Map<String, Object>> getDeviceOrderInfo(Map<String, Integer> map);/*** @author yeqian* @param* @return* @Description TODO 覆盖pageHelp的计算总数方法* @Date 2021/6/3 16:57*/ Long getDeviceOrderInfo_COUNT();
-
在去xml中写具体sql💪
<!--查询所有的订单详细信息--> <select id="getDeviceOrderInfo_COUNT" resultType="Long" useCache="false"> SELECT COUNT(1) FROM orderInfo </select>
-
再次查询,从2s的延迟降低到毫秒级:happy:
小结
原来是分页插件中的计算
Count
的sql语句,会将需要分页的所有数据查出来然后生成一个临时表,再去计算Count
。如果数据量此时比较大,那么生产临时表这步因为多查询了一次表,所以会导致最后
Count
计算会十分慢,从而影响分页的结果。解决办法:
覆盖原
Count
的sql,根据官方文档,自定义。注意返回值类型(Long
)与方法名(原名_COUNT
)
这篇关于Mybatis分页插件(pagehelper)数据量稍大出现查询慢的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!