MyBatis-Plus打印SQL配置的四种方法

 更新时间:2026年04月01日 09:06:09   作者:mcooiedo  
本文介绍了MyBatis-Plus打印SQL的四种配置方法,包括通过application.properties或application.yml配置、自定义SQL日志输出方式、通过代码配置MyBatis-Plus以及结合日志框架(推荐使用SLF4J+Logback),需要的朋友可以参考下

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

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

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

1.1 在 application.properties 中配置

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

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

1.2 在 application.yml 中配置

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 配置日志实现类:

@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,并定义日志输出格式:

<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.]

到此这篇关于MyBatis-Plus打印SQL配置的四种方法的文章就介绍到这了,更多相关MyBatis-Plus打印SQL配置内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Groovy编程入门攻略

    Groovy编程入门攻略

    这篇文章主要介绍了Groovy编程入门攻略,Groovy是一种同样使用Java虚拟机的动态语言,需要的朋友可以参考下
    2015-07-07
  • Java通过SSM完成水果商城批发平台流程

    Java通过SSM完成水果商城批发平台流程

    这是一个使用了java+SSM开发的网上水果商城批发平台,是一个实战小练习,具有水果商城批发该有的所有功能,感兴趣的朋友快来看看吧
    2022-06-06
  • Java异常处理操作实例小结

    Java异常处理操作实例小结

    这篇文章主要介绍了Java异常处理操作,结合实例形式总结分析了java异常处理常见操作情况与相关处理技巧,需要的朋友可以参考下
    2019-07-07
  • java后台实现js关闭本页面,父页面指定跳转或刷新操作

    java后台实现js关闭本页面,父页面指定跳转或刷新操作

    这篇文章主要介绍了java后台实现js关闭本页面,父页面指定跳转或刷新操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-11-11
  • SpringBoot实现权限验证的示例步骤

    SpringBoot实现权限验证的示例步骤

    权限验证是一种用于控制对系统资源和操作的访问的机制。它允许开发人员定义谁可以执行特定操作或访问特定资源,并确保只有经过授权的用户才能执行这些操作,这篇文章主要介绍了SpringBoot实现权限验证,需要的朋友可以参考下
    2023-08-08
  • 浅谈Java中Collections.sort对List排序的两种方法

    浅谈Java中Collections.sort对List排序的两种方法

    本文介绍了Java中Collections.sort对List排序的两种方法以及Comparable 与Comparator区别,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-12-12
  • 基于java时区转换夏令时的问题及解决方法

    基于java时区转换夏令时的问题及解决方法

    下面小编就为大家分享一篇基于java时区转换夏令时的问题及解决方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2017-11-11
  • Mybatis Plus 自定义方法实现分页功能的示例代码

    Mybatis Plus 自定义方法实现分页功能的示例代码

    这篇文章主要介绍了Mybatis Plus 自定义方法实现分页功能的示例代码,代码简单易懂,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-08-08
  • java响应式编程之Reactor使用示例解析

    java响应式编程之Reactor使用示例解析

    这篇文章主要为大家介绍了java响应式编程之Reactor使用示例解析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-07-07
  • Android中Socket通信的实现方法概述

    Android中Socket通信的实现方法概述

    这篇文章主要介绍了Android中Socket通信的实现方法,很有实用价值,需要的朋友可以参考下
    2014-08-08

最新评论