Mybatis-Plus中的性能分析拦截器,用于输出每条SQL语句执行时间,对SQL性能执行分析,开发环境使用,超过指定时间,停止运行。
具体步骤
- 在配置类中加入性能分析插件
- 在配置文件中设置开发环境
- 测试
具体实现
在MyBatis-Plus入门案例基础上进行修改。
在配置类中加入性能分析插件
package com.example.mybatis_plus_demo.config;
import com.baomidou.mybatisplus.core.injector.ISqlInjector;
import com.baomidou.mybatisplus.extension.injector.LogicSqlInjector;
import com.baomidou.mybatisplus.extension.plugins.OptimisticLockerInterceptor;
import com.baomidou.mybatisplus.extension.plugins.PaginationInterceptor;
import com.baomidou.mybatisplus.extension.plugins.PerformanceInterceptor;
import org.mybatis.spring.annotation.MapperScan;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.Profile;
@MapperScan("com.example.mybatis_plus_demo.mapper")
@Configuration
public class MybatisPlusConfig {
//乐观锁插件
@Bean
public OptimisticLockerInterceptor optimisticLockerInterceptor() {
return new OptimisticLockerInterceptor();
}
//分页插件
@Bean
public PaginationInterceptor paginationInterceptor() { return new PaginationInterceptor(); }
//逻辑删除插件
@Bean
public ISqlInjector sqlInjector() {
return new LogicSqlInjector();
}
/*
*SQL执行性能分析插件
*
* 三种环境:
* dev:开发环境
* test:测试环境
* prod:生产环境
*
*/
@Bean
@Profile({"dev","test"}) //设置dev test环境开启
public PerformanceInterceptor performanceInterceptor() {
PerformanceInterceptor performanceInterceptor = new PerformanceInterceptor();
performanceInterceptor.setMaxTime(100); //ms,超过此处设置的ms则sql不执行
performanceInterceptor.setFormat(true);
return performanceInterceptor;
}
}
在配置文件中设置开发环境
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver
spring.datasource.url=jdbc:mysql://localhost:3306/mybatis_plus?serverTimezone=GMT%2B8
spring.datasource.password=1234
spring.datasource.username=root
# 配置sql输出日志
mybatis-plus.configuration.log-impl=org.apache.ibatis.logging.stdout.StdOutImpl
#配置逻辑删除标识
mybatis-plus.global-config.db-config.logic-delete-value=1
mybatis-plus.global-config.db-config.logic-not-delete-value=0
# 环境设置:dev、test、prod
spring.profiles.active=dev
测试
@Test
void addUser() {
User user = new User();
user.setName("pdd");
user.setAge(30);
user.setEmail("lucy@qq.com");
int insert = userMapper.insert(user);
System.out.println("insert:" + insert);
}
先设置maxtime为100,查看结果:
将maxtime修改为500,查看结果: