Mybatis-Plus分页插件查询慢解决方案

简介: Mybatis-Plus分页插件查询慢解决方案

问题

需求反馈前端界面查询速度很慢。

分析

  1. f12查看接口响应时间达到了5.47s。

  1. 查看后端代码逻辑,就是传了些参数,分页查询了一个列表的数据。分页插件使用的是mybatis-plus的分页插件,PaginationInterceptor。
  2. 把后端调用的sql单独拿出来在navicat中进行执行,才0.54s左右,其实很快了,数据量也不大。分页查询即使加上查总数的count语句,单独拿出来在navicat中执行,也很快。
  3. 综上,总体来说这次响应速度慢和sql查询的关系不是很大,查看后台日志时发现,在打印出sql语句之后,会卡顿一会儿,随后才会输出count语句。查阅mybatis-plus插件的官网发现,其中有个参数: optimizeCountSql , 默认为true。在编写count语句的时候,会对sql语句进行优化。

以此推断应该是这个引起的,因为业务中sql语句还比较复杂,这里要解析进行优化的话,可能需要花费一点儿时间。尤其其中有一些难以解析的表达式,更是耗费时间。

解决方案

  1. 将上述属性设置为false,测试之后解决问题,接口的速度达到500多毫秒。
Page page = new Page();
page.setCurrent(MapUtils.getIntValue(paramMap, "pageNum"));
page.setSize(MapUtils.getIntValue(paramMap, "pageSize"));
// 关闭count sql的优化,解决前端查询慢的效率问题。
page.setOptimizeCountSql(false);
  1. 还有种方案,就是这里自定义一个count查询的sql,不用其优化的sql。即利用下图中的countId属性来解决。或者单独把总数查询出来后,再来设置其总数。

后续思考

此例中,sql语句写的比较复杂,查询的字段中用了很多转换函数,后续也需要继续优化。是否考虑关于字典的优化放在前端去显示。或者数据库冗余字段,直接查询,不用转换?

目录
相关文章
|
23天前
|
XML Java 数据库连接
mybatis中在xml文件中通用查询结果列如何使用
mybatis中在xml文件中通用查询结果列如何使用
20 0
|
25天前
|
SQL Java 数据库连接
【mybatis】第一篇,Springboot中使用插件PageHelper不生效解决方案
【mybatis】第一篇,Springboot中使用插件PageHelper不生效解决方案
|
4天前
|
SQL
MyBatis-Plus-Join关联查询
MyBatis-Plus-Join关联查询
|
4天前
|
SQL XML Java
MyBatis-Plus多表关联查询
MyBatis-Plus多表关联查询
|
4天前
|
SQL Java 数据库连接
Mybatis Plus字段为空值时未更新解决方案
Mybatis Plus字段为空值时未更新解决方案
|
5天前
|
SQL 前端开发 Java
通过使用Mybatis插件来实现数据的分页功能
通过使用Mybatis插件来实现数据的分页功能
|
9天前
|
SQL XML Java
Mybatis-Plus插件扩展MybatisX
Mybatis-Plus插件扩展MybatisX
17 0
|
9天前
|
SQL XML API
Mybatis-Plus实现查询操作
Mybatis-Plus实现查询操作
14 0
Mybatis-Plus实现查询操作
|
10天前
|
Java 数据库连接 mybatis
MyBatis-Plus查询工具类
MyBatis-Plus是一个MyBatis的增强工具类库,提供了许多实用的查询工具类。
6 0
|
11天前
|
SQL Java 数据库连接
Javaweb之Mybatis的基础操作之查询操作的详细解析
Javaweb之Mybatis的基础操作之查询操作的详细解析
20 0