(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 日志的配置示例吗?

相关推荐
曹牧2 小时前
Spring Boot:如何测试Java Controller中的POST请求?
java·开发语言
爬山算法3 小时前
Hibernate(90)如何在故障注入测试中使用Hibernate?
java·后端·hibernate
kfyty7253 小时前
集成 spring-ai 2.x 实践中遇到的一些问题及解决方案
java·人工智能·spring-ai
猫头虎3 小时前
如何排查并解决项目启动时报错Error encountered while processing: java.io.IOException: closed 的问题
java·开发语言·jvm·spring boot·python·开源·maven
李少兄3 小时前
在 IntelliJ IDEA 中修改 Git 远程仓库地址
java·git·intellij-idea
忆~遂愿3 小时前
ops-cv 算子库深度解析:面向视觉任务的硬件优化与数据布局(NCHW/NHWC)策略
java·大数据·linux·人工智能
小韩学长yyds4 小时前
Java序列化避坑指南:明确这4种场景,再也不盲目实现Serializable
java·序列化
仟濹4 小时前
【Java基础】多态 | 打卡day2
java·开发语言
Re.不晚4 小时前
JAVA进阶之路——无奖问答挑战2
java·开发语言
Ro Jace5 小时前
计算机专业基础教材
java·开发语言