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

MyBatisPlus SQL执行时间过长问题
本文介绍了解决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

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、付费专栏及课程。

余额充值