(10)MyBatis的日志工厂(了解即可后续集成spring)

✅ 一句话核心

MyBatis 本身不实现日志,而是通过日志工厂适配你项目中已有的日志框架(如 SLF4J、Log4j 等),用于输出 SQL 语句、参数、结果等,方便调试。


🔧 日志工厂支持的实现(按优先级自动探测)

MyBatis 启动时会按以下顺序自动查找日志实现(找到即停):

  1. SLF4J(最推荐,现代项目标配)
  2. Apache Commons Logging
  3. Log4j2
  4. Log4j
  5. JDK logging(java.util.logging)
  6. NO_LOGGING(关闭日志)

💡 如果你用 Spring Boot,默认集成 SLF4J + Logback,MyBatis 会自动使用它。


🛠 如何开启 SQL 日志?

方法一:在 mybatis-config.xml 中显式指定(可选)
xml 复制代码
<settings>
  <setting name="logImpl" value="SLF4J"/>
</settings>

MyBatis 没有"自带"的日志实现(除了 STDOUT),它不用引入任何依赖

常用值:SLF4JLOG4JLOG4J2JDK_LOGGINGNO_LOGGING

方法二:什么都不配(推荐)

只要 classpath 里有 SLF4J 或 Log4j,MyBatis 会自动用------无需配置


🔍 日志能看什么?(开发必备)

开启后,控制台会输出:

log 复制代码
==>  Preparing: SELECT * FROM user WHERE id = ?
==> Parameters: 1(Integer)
<==    Columns: id, user_name, email
<==        Row: 1, 张三, zhangsan@example.com
<==      Total: 1
  • 执行的 SQL
  • 绑定的参数(防注入,显示 ? 替代)
  • 返回结果行数

⚠️ 大厂避坑指南

  1. 不要用 System.out.println 调试 SQL → 用日志!

  2. 生产环境保留 SQL 日志开关 :通过日志级别(如 debug)控制,避免性能损耗。

    yaml 复制代码
    # Spring Boot application.yml
    logging:
      level:
        com.your.mapper: debug
  3. 如果看不到日志

    • 检查是否引入了日志依赖(如 slf4j-api + logback-classic
    • 检查日志级别是否为 DEBUG(MyBatis 日志是 DEBUG 级别)

✅ 总结

问题 答案
MyBatis 用什么打日志? 适配你项目已有的日志框架(优先 SLF4J)
需要手动配置吗? 一般不用,除非你想强制指定
如何看到 SQL? 确保日志级别为 DEBUG,Mapper 包路径开 debug
生产能开吗? 可以,但建议按需开启(通过日志配置动态控制)

💡 记住:SQL 日志 = 开发效率神器,但靠日志级别管控,不是硬编码。

需要我给你一个 Spring Boot 下完整开启 MyBatis SQL 日志的配置示例吗?

相关推荐
梦未7 小时前
Spring控制反转与依赖注入
java·后端·spring
喜欢流萤吖~7 小时前
Lambda 表达式
java
ZouZou老师7 小时前
C++设计模式之适配器模式:以家具生产为例
java·设计模式·适配器模式
曼巴UE57 小时前
UE5 C++ 动态多播
java·开发语言
VX:Fegn08957 小时前
计算机毕业设计|基于springboot + vue音乐管理系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·后端·课程设计
程序员鱼皮7 小时前
刚刚,IDEA 免费版发布!终于不用破解了
java·程序员·jetbrains
Hui Baby8 小时前
Dubbo/springCloud同机房收敛
spring·spring cloud·dubbo
Hui Baby8 小时前
Nacos容灾俩种方案对比
java
曲莫终8 小时前
Java单元测试框架Junit5用法一览
java