Mybatis-Plus分页插件查询慢解决方案
Posted hoho_12
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Mybatis-Plus分页插件查询慢解决方案相关的知识,希望对你有一定的参考价值。
问题
需求反馈前端界面查询速度很慢。
分析
f12查看接口响应时间达到了5.47s。
查看后端代码逻辑,就是传了些参数,分页查询了一个列表的数据。分页插件使用的是mybatis-plus的分页插件,PaginationInterceptor。
把后端调用的sql单独拿出来在navicat中进行执行,才0.54s左右,其实很快了,数据量也不大。分页查询即使加上查总数的count语句,单独拿出来在navicat中执行,也很快。
综上,总体来说这次响应速度慢和sql查询的关系不是很大,查看后台日志时发现,在打印出sql语句之后,会卡顿一会儿,随后才会输出count语句。查阅mybatis-plus插件的官网发现,其中有个参数: optimizeCountSql , 默认为true。在编写count语句的时候,会对sql语句进行优化。
以此推断应该是这个引起的,因为业务中sql语句还比较复杂,这里要解析进行优化的话,可能需要花费一点儿时间。尤其其中有一些难以解析的表达式,更是耗费时间。
解决方案
将上述属性设置为false,测试之后解决问题,接口的速度达到500多毫秒。
Page page = new Page();
page.setCurrent(MapUtils.getIntValue(paramMap, "pageNum"));
page.setSize(MapUtils.getIntValue(paramMap, "pageSize"));
// 关闭count sql的优化,解决前端查询慢的效率问题。
page.setOptimizeCountSql(false);
还有种方案,就是这里自定义一个count查询的sql,不用其优化的sql。即利用下图中的countId属性来解决。或者单独把总数查询出来后,再来设置其总数。
后续思考
此例中,sql语句写的比较复杂,查询的字段中用了很多转换函数,后续也需要继续优化。是否考虑关于字典的优化放在前端去显示。或者数据库冗余字段,直接查询,不用转换?
以上是关于Mybatis-Plus分页插件查询慢解决方案的主要内容,如果未能解决你的问题,请参考以下文章
Mybatis-plus 3.4版本 分页插件配置 设置单次查询最大记录数及突破最大限制查询
Mybatis-plus 3.4版本 分页插件配置 设置单次查询最大记录数及突破最大限制查询