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

相关推荐
code_li27 分钟前
聊聊支付宝架构
java·开发语言·架构
CC.GG1 小时前
【Linux】进程概念(五)(虚拟地址空间----建立宏观认知)
java·linux·运维
以太浮标2 小时前
华为eNSP模拟器综合实验之- AC+AP无线网络调优与高密场景
java·服务器·华为
Mr__Miss2 小时前
JAVA面试-框架篇
java·spring·面试
小马爱打代码2 小时前
SpringBoot:封装 starter
java·spring boot·后端
STARSpace88882 小时前
SpringBoot 整合个推推送
java·spring boot·后端·消息推送·个推
码农幻想梦2 小时前
实验八 获取请求参数及域对象共享数据
java·开发语言·servlet
a努力。3 小时前
2026 AI 编程终极套装:Claude Code + Codex + Gemini CLI + Antigravity,四位一体实战指南!
java·开发语言·人工智能·分布式·python·面试
Dylan的码园3 小时前
功能包介绍 : calendar
java·jvm·eclipse
二川bro3 小时前
Java集合类框架的基本接口有哪些?
java·开发语言·python