Cause: com.baomidou.mybatisplus.core.exceptions.MybatisPlusException:  The SQL execution time is too

本文介绍了解决MyBatisPlus中SQL执行时间过长的问题,通过调整配置文件中的PerformanceInterceptor组件的maxTime值来优化SQL执行效率。

mybatis plus查询遇到的坑:

org.mybatis.spring.MyBatisSystemException: nested exception is org.apache.ibatis.exceptions.PersistenceException: 
### Error querying database.  Cause: com.baomidou.mybatisplus.core.exceptions.MybatisPlusException:  The SQL execution time is too large, please optimize ! 
### The error occurred while handling results
### Cause: com.baomidou.mybatisplus.core.exceptions.MybatisPlusException:  The SQL execution time is too large, please optimize ! 

解决办法:

    修改配置文件:的value值为1000。配置如下

<bean id="sqlSessionFactory" class="com.baomidou.mybatisplus.extension.spring.MybatisSqlSessionFactoryBean">
	<property name="dataSource" ref="dataSource"/>
	<property name="databaseIdProvider" ref="databaseIdProvider" />
	<property name="plugins">
		<array>
			<bean id="paginationInterceptor"
				  class="com.baomidou.mybatisplus.extension.plugins.PaginationInterceptor">
				<property name="dialectType" value="mysql" />
			</bean>
			<bean id="performanceInterceptor"
				class="com.baomidou.mybatisplus.extension.plugins.PerformanceInterceptor" >
				<property name="maxTime" value="1000" />
				<property name="format" value="true" />
			</bean>
		</array>
	</property>
</bean>

   转载请注原文地址: https://blog.youkuaiyun.com/java_jack1/article/details/96429002

msg: "nested exception is org.apache.ibatis.exceptions.PersistenceException: ↵### Error querying database. Cause: com.baomidou.mybatisplus.core.exceptions.MybatisPlusException: Error: Method queryTotal execution error of sql : ↵ SELECT COUNT(1) FROM (SELECT a.id, a.seq, a.system_id, a.name, a.no, a.sys_code, a.code, a.major_version, a.minor_version, a.is_monitor, a.flow_state, a.state, (CASE a.type WHEN 1 THEN '新建' WHEN 2 THEN '修订' WHEN 3 THEN '升版' END) type, a.is_deleted, a.revise_desc, a.create_user, a.create_time, a.update_user, a.update_time, (CASE a.type WHEN 1 THEN 'WF_RSM_PLAN_DRA' WHEN 2 THEN 'WF_RSM_PLAN_REV' WHEN 3 THEN 'WF_RSM_PLAN_UPG' END) reportType, c.process_id AS processId, b.powerplant_id plant_id, b.unit_id, b.cn_name AS system_cn_name, b.cn_name systemName, b.code AS systemCode FROM rsm_plan a JOIN rsm_cf_system b ON a.system_id = b.id LEFT JOIN rsm_process_log c ON a.id = c.rsm_id WHERE a.is_deleted = 0 AND b.is_deleted = 0 AND a.flow_state NOT IN ('90', 'A0') AND (b.cn_name LIKE concat('%', ?, '%') OR b.code LIKE concat('%', ?, '%')) AND b.powerplant_id = ? AND b.is_show = 1) t WHERE 1 = 1 ↵↵### The error may exist in cn/com/cnnp/erdb/rsm/sm/system/mapper/PlanMapper.xml↵### The error may involve defaultParameterMap↵### The error occurred while setting parameters↵### SQL: select a.id, a.seq, a.system_id , a.name, a.no, a.sys_code, a.code, a.major_version, a.minor_version, a.is_monitor, a.flow_state, a.state, (case a.type when 1 then '新建' when 2 then '修订' when 3 then '升版' end ) type, a.is_deleted, a.revise_desc, a.create_user, a.create_time, a.update_user, a.update_time, (case a.type when 1 then 'WF_RSM_PLAN_DRA' when 2 then 'WF_RSM_PLAN_REV' when 3 then 'WF_RSM_PLAN_UPG' end) reportType, c.process_id as processId,b.powerplant_id plant_id,b.unit_id,b.cn_name as system_cn_name, b.cn_name systemName,b.code AS systemCode from rsm_plan a join rsm_cf_system b on a.system_id=b.id left join rsm_process_log c on a.id=c.rsm_id where a.is_deleted = 0 and b.is_deleted=0 and a.flow_state not in ('90','A0') AND (b.cn_name like concat('%',?,'%') or b.code like concat('%', ?,'%')) and b.powerplant_id = ? and b.is_show=1↵### Cause: com.baomidou.mybatisplus.core.exceptions.MybatisPlusException: Error: Method queryTotal execution error of sql : ↵ SELECT COUNT(1) FROM (SELECT a.id, a.seq, a.system_id, a.name, a.no, a.sys_code, a.code, a.major_version, a.minor_version, a.is_monitor, a.flow_state, a.state, (CASE a.type WHEN 1 THEN '新建' WHEN 2 THEN '修订' WHEN 3 THEN '升版' END) type, a.is_deleted, a.revise_desc, a.create_user, a.create_time, a.update_user, a.update_time, (CASE a.type WHEN 1 THEN 'WF_RSM_PLAN_DRA' WHEN 2 THEN 'WF_RSM_PLAN_REV' WHEN 3 THEN 'WF_RSM_PLAN_UPG' END) reportType, c.process_id AS processId, b.powerplant_id plant_id, b.unit_id, b.cn_name AS system_cn_name, b.cn_name systemName, b.code AS systemCode FROM rsm_plan a JOIN rsm_cf_system b ON a.system_id = b.id LEFT JOIN rsm_process_log c ON a.id = c.rsm_id WHERE a.is_deleted = 0 AND b.is_deleted = 0 AND a.flow_state NOT IN ('90', 'A0') AND (b.cn_name LIKE concat('%', ?, '%') OR b.code LIKE concat('%', ?, '%')) AND b.powerplant_id = ? AND b.is_show = 1) t WHERE 1 = 1 ↵"问题解析
最新发布
12-18
MyBatis-Plus中`Method queryTotal`执行SQL出错(`com.baomidou.mybatisplus.core.exceptions.MybatisPlusException`),可能有以下原因及解决方法: ### 特殊字符处理异常 MyBatis在处理xml文件中sql映射过程时,对于 `--` 等特殊字符的处理异常可能导致该问题。解决办法是编辑的脚本尽量使用官方提供的语法,避免出现错误[^2]。 ### SQL语句本身问题 检查SQL语句是否存在语法错误、表名或列名错误、数据类型不匹配等问题。例如,在报错内容 `SELECT COUNT(1) FROM ( SELECT id,star,like,author,created,description,title,user_id,recent,content,status FROM m_blog ORDER BY created DESC ) TOTAL` 中,`like` 是SQL的关键字,作为列名使用可能会引发问题,需要使用反引号(`)将其包裹,正确的语句如下: ```sql SELECT COUNT(1) FROM ( SELECT id, star, `like`, author, created, description, title, user_id, recent, content, status FROM m_blog ORDER BY created DESC ) TOTAL; ``` ### 数据库连接和权限问题 要确保数据库连接正常,当前用户具备执行该查询的权限。可以通过以下代码检查数据库连接: ```python import psycopg2 try: conn = psycopg2.connect( database="your_database", user="your_user", password="your_password", host="your_host", port="your_port" ) print("连接成功") except psycopg2.Error as e: print(f"连接失败: {e}") ``` ### 分页插件配置问题 如果使用了分页插件,要确保配置正确。例如,在Spring配置文件中配置 `SqlSessionFactory` 时,应使用MyBatis-Plus中的 `MybatisSqlSessionFactoryBean`,而不是 `org.mybatis.spring.SqlSessionFactoryBean`: ```xml <bean id="sqlSessionFactory" class="com.baomidou.mybatisplus.extension.spring.MybatisSqlSessionFactoryBean"> <property name="dataSource" ref="dataSource"/> <!--注册映射文件--> <property name="mapperLocations"> <array> <value>classpath:mappers/*.xml</value> </array> </property> <!--引入MyBatis的配置文件--> <property name="configLocation" value="classpath:mybatis-config.xml"/> </bean> ```
评论 1
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值