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

相关推荐
AI行业学习8 分钟前
CC-Switch v3.16.1 官方下载 | 安装配置详细教程【2026.6.10】
java·开发语言·vue.js·python·mysql·eclipse·html
云烟成雨TD25 分钟前
Spring AI 1.x 系列【59】容器化开发支持:Docker Compose 与 Testcontainers
人工智能·spring·docker
不负岁月无痕1 小时前
C++ 模板核心内容与高频面试题汇总
java·开发语言·c++
Flittly1 小时前
【AgentScope Java新手村系列】(2)第一个Agent-基础对话
java·spring boot·spring·ai
摇滚侠1 小时前
Spring MVC 不是一个单独的框架,是 Spring 框架的一个模块
java·spring·mvc
阿正的梦工坊1 小时前
【Rust】04-借用、引用与切片
java·数据库·rust
devilnumber1 小时前
静态代理 & 动态代理:实战运用 + 场景区别 + 怎么选
java·开发语言·代理模式
Upsy-Daisy2 小时前
Hermes Agent 学习笔记 02:安装、配置与第一次运行
java·前端·数据库
SuperArc19992 小时前
SpringBoot+Slf4j+Log4j2+mybatis 日志整合
spring boot·mybatis·log4j2·slf4j·日志整合
用户4682557459132 小时前
Testcontainers 在 Windows Docker Desktop 上跑不通:协议层不兼容 + 4 种可行环境
java·后端