mybatisPlus打印sql配置

MyBatis-Plus 提供了方便的配置方式来打印 SQL 查询语句,以便进行调试和性能分析。可以通过配置 log 来输出 SQL 语句以及执行的参数。

方法 1:通过 application.properties 或 application.yml 配置打印 SQL

可以通过配置 application.properties 或 application.yml 文件来启用 MyBatis-Plus 的 SQL 打印功能。

1.1 在 application.properties 中配置

bash 复制代码
# 开启 MyBatis-Plus SQL 打印日志
mybatis-plus.configuration.log-impl=org.apache.ibatis.logging.stdout.StdOutImpl

这个配置会使用 StdOutImpl 打印 SQL 到控制台。

1.2 在 application.yml 中配置

yaml 复制代码
mybatis-plus:
  configuration:
    log-impl: org.apache.ibatis.logging.stdout.StdOutImpl

方法 2:自定义 SQL 日志输出方式

MyBatis-Plus 使用了 MyBatis 的日志框架,因此可以通过配置 MyBatis 的日志实现方式来控制日志的输出。MyBatis 提供了多种日志实现,可以通过配置来选择输出方式。

常见的日志实现包括:

复制代码
SLF4J(推荐)
CommonsLogging
Log4j
Log4j2
JDKLogging(Java 默认日志)

如果使用的是 SLF4J,则可以通过配置 logback.xml 来控制 SQL 的输出。

方法 3:通过代码配置 MyBatis-Plus

如果希望在代码中配置 SQL 打印,而不是依赖于配置文件,可以通过在 MyBatis 配置中显式设置日志工厂。

3.1 配置 SqlSessionFactory 和 Logging 组件

在 Java 配置中,可以为 MyBatis 配置日志实现类:

java 复制代码
@Bean
public SqlSessionFactory sqlSessionFactory(DataSource dataSource) throws Exception {
    MybatisSqlSessionFactoryBean sessionFactory = new MybatisSqlSessionFactoryBean();
    sessionFactory.setDataSource(dataSource);
    
    // 设置 MyBatis-Plus 的日志实现类
    org.apache.ibatis.logging.LogFactory.useSlf4jLogging();
    
    return sessionFactory.getObject();
}

方法 4:结合日志框架(推荐使用 SLF4J + Logback)

结合 SLF4J 和 Logback 来打印 SQL 日志,这样能够提供更强的日志管理能力。以下是一个例子:

4.1 配置 logback.xml

首先,需要在 logback.xml 配置文件中设置日志级别为 DEBUG,并定义日志输出格式:

xml 复制代码
<configuration>

  <!-- 设置日志级别 -->
  <logger name="com.baomidou.mybatisplus" level="DEBUG" />
  
  <logger name="org.mybatis" level="DEBUG" />
  
  <appender name="stdout" class="ch.qos.logback.core.ConsoleAppender">
    <encoder>
      <pattern>%d{yyyy-MM-dd HH:mm:ss} [%thread] %-5level %logger{36} - %msg%n</pattern>
    </encoder>
  </appender>

  <root level="INFO">
    <appender-ref ref="stdout" />
  </root>

</configuration>
``
[Something went wrong, please try again later.]
相关推荐
小白教程1 小时前
MySQL数据库的安全性防护
数据库·mysql
Lion Long1 小时前
CodeBuddy 中国版 Cursor 实战:Redis+MySQL双引擎驱动〈王者荣耀〉战区排行榜
数据库·redis·mysql·缓存·腾讯云·codebuddy首席试玩官·codebuddy
apcipot_rain4 小时前
【应用密码学】实验五 公钥密码2——ECC
前端·数据库·python
辛一一6 小时前
neo4j图数据库基本概念和向量使用
数据库·neo4j
LJianK17 小时前
关系型数据库和非关系型数据库
sql
巨龙之路7 小时前
什么是时序数据库?
数据库·时序数据库
蔡蓝7 小时前
binlog日志以及MySQL的数据同步
数据库·mysql
是店小二呀8 小时前
【金仓数据库征文】金融行业中的国产化数据库替代应用实践
数据库·金融·数据库平替用金仓·金仓数据库2025征文
炒空心菜菜9 小时前
SparkSQL 连接 MySQL 并添加新数据:实战指南
大数据·开发语言·数据库·后端·mysql·spark
多多*9 小时前
算法竞赛相关 Java 二分模版
java·开发语言·数据结构·数据库·sql·算法·oracle