Spring Boot + Mybatis Plus3.1 实现 SQL 打印

原文连接-执行SQL分析打印

项目目录

Spring Boot + Mybatis Plus3.1 实现 SQL 打印

后续说明:

  1. 完成mapper等基本功能设置。
  2. 只是要看 执行的SQL打印

最终在 Console 面板的效果:

Spring Boot + Mybatis Plus3.1 实现 SQL 打印

配置步骤

1. 在 pom.xml 加入最新的依赖

p6spy在maven 库的链接
例如:

<dependencies>
    <dependency>
      <groupId>p6spy</groupId>
      <artifactId>p6spy</artifactId>
      <version>3.8.1</version>
    </dependency>
 </dependencies>

2. 在 application.properties 配置(两处设置)

#在jdbc:后加p6spy
spring.datasource.url=jdbc:p6spy:mysql://127.0.0.1:3306/  #后面省略

#p6spy
spring.datasource.driver-class-name:com.p6spy.engine.spy.P6SpyDriver

新增 spy.properties

module.log=com.p6spy.engine.logging.P6LogFactory,com.p6spy.engine.outage.P6OutageFactory
# 自定义日志打印
logMessageFormat=com.baomidou.mybatisplus.extension.p6spy.P6SpyLogger
#日志输出到控制台
appender=com.baomidou.mybatisplus.extension.p6spy.StdoutLogger
# 使用日志系统记录 sql
#appender=com.p6spy.engine.spy.appender.Slf4JLogger
# 设置 p6spy driver 代理
deregisterdrivers=true
# 取消JDBC URL前缀
useprefix=true
# 配置记录 Log 例外,可去掉的结果集有error,info,batch,debug,statement,commit,rollback,result,resultset.
excludecategories=info,debug,result,batch,resultset
# 日期格式
dateformat=yyyy-MM-dd HH:mm:ss
# 实际驱动可多个
#driverlist=org.h2.Driver
# 是否开启慢SQL记录
outagedetection=true
# 慢SQL记录标准 2 秒
outagedetectioninterval=2

Spring Boot + Mybatis Plus3.1 实现 SQL 打印

测试方法 (执行普通的 数据库操作即可)

	@Autowired
	private StudentMapper studentMapper;
	
	@Test
	public void testUpdate() {
		// 更新
		Student student = new Student();
		student.setId(2L);
		student.setAge(50);
		student.setName("吴彦祖");
		
		studentMapper.update(student, new QueryWrapper<Student>().eq("id", "12"));
		System.out.println(student);
	}