news 2026/6/10 14:35:09

mybatis plus打印sql日志

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
mybatis plus打印sql日志

1、官方文档

使用配置 | MyBatis-Plus

2、日志实现

MyBatis-Plus 提供了多种日志实现(log-impl),用于记录 SQL 语句和相关操作,帮助开发者进行调试和监控数据库操作。以下是一些可用的日志实现及其说明:

  1. StdOutImpl:将日志信息输出到控制台,适用于开发和测试环境。在配置文件中设置log-implorg.apache.ibatis.logging.stdout.StdOutImpl可以开启控制台 SQL 日志打印 。

  2. NoLoggingImpl:不记录任何日志信息,适用于生产环境,以避免日志泄露可能的敏感信息。配置方式为设置log-implorg.apache.ibatis.logging.nologging.NoLoggingImpl来关闭 SQL 日志打印 。

  3. Slf4jImpl:使用 SLF4J 作为日志框架,可以与 Logback、Log4j2 等日志实现配合使用。配置方式为设置log-implorg.apache.ibatis.logging.slf4j.Slf4jImpl

  4. JakartaCommonsLoggingImplJdk14LoggingImplLog4jImpl等:这些是 MyBatis-Plus 支持的其他日志实现,可以根据项目中使用的日志框架进行选择 。

  5. 自定义日志实现:MyBatis-Plus 还允许开发者通过实现Log接口来扩展自定义的日志输出方式。可以使用LogFactoryuseCustomLogging方法来指定自定义日志类。

此外,MyBatis-Plus 通过LogFactory日志工厂来确定使用哪种日志实现。如果没有明确指定,它会尝试使用一系列内置日志实现,直到找到合适的日志类或者禁用日志功能。

在实际使用中,可以根据项目需求和环境配置相应的日志实现,以便于更好地监控和调试应用程序。例如,可以在项目启动时通过控制台输出的提示信息来确认当前使用的日志实现方式。如果需要将 SQL 日志和参数打印到日志文件中,可以考虑使用支持文件输出的日志框架,如 Logback 或 Log4j2,并进行相应的配置。

3、自定义日志实现(推荐)

创建自定义日志实现

首先,我们需要创建一个实现了org.apache.ibatis.logging.Log接口的类,该类会将所有原本打算以DEBUG级别记录的日志改为以INFO级别记录。

package com.ybw.config; import org.apache.ibatis.logging.Log; import org.slf4j.Logger; import org.slf4j.LoggerFactory; /** * mybatis日志级别改为info * * @author ybw * @version V1.0 * @className InfoLevelLog * @date 2024/12/2 **/ public class InfoLevelLogger implements Log { private final Logger logger; public InfoLevelLogger(String clazz) { this.logger = LoggerFactory.getLogger(clazz); } @Override public boolean isDebugEnabled() { return logger.isInfoEnabled(); } @Override public void error(String s, Throwable e) { logger.error(s, e); } @Override public void error(String s) { logger.error(s); } @Override public void debug(String s) { // 修改这里 logger.info(s); } @Override public void warn(String s) { logger.warn(s); } @Override public boolean isTraceEnabled() { // 如果需要,也可以将TRACE级别的日志改为INFO return logger.isInfoEnabled(); } @Override public void trace(String s) { // 修改这里 logger.trace(s); } }

注册自定义日志实现

mybatis配置
mybatis: configuration: log-impl: com.ybw.config.InfoLevelLogger
mybatis-plus配置
mybatis-plus: configuration: log-impl: com.ybw.config.InfoLevelLogger

测试验证

[INFO ] 2024-12-02 14:37:20.403 [main] org.mybatis.spring.SqlSessionUtils - Creating a new SqlSession [INFO ] 2024-12-02 14:37:20.420 [main] org.mybatis.spring.SqlSessionUtils - SqlSession [org.apache.ibatis.session.defaults.DefaultSqlSession@7a3643e3] was not registered for synchronization because synchronization is not active [INFO ] 2024-12-02 14:37:20.517 [main] o.m.s.t.SpringManagedTransaction - JDBC Connection [com.alibaba.druid.proxy.jdbc.ConnectionProxyImpl@3e4afd10] will not be managed by Spring [INFO ] 2024-12-02 14:37:20.528 [main] c.y.mapper.TestYearMapper.selectList - ==> Preparing: SELECT id,receive_year FROM test_year WHERE (receive_year = ?) [INFO ] 2024-12-02 14:37:20.660 [main] c.y.mapper.TestYearMapper.selectList - ==> Parameters: 2024(Integer) [INFO ] 2024-12-02 14:37:20.751 [main] c.y.mapper.TestYearMapper.selectList - <== Columns: id, receive_year [INFO ] 2024-12-02 14:37:20.753 [main] c.y.mapper.TestYearMapper.selectList - <== Row: 1, 2024-01-01 [INFO ] 2024-12-02 14:37:20.756 [main] c.y.mapper.TestYearMapper.selectList - <== Total: 1 [INFO ] 2024-12-02 14:37:20.762 [main] org.mybatis.spring.SqlSessionUtils - Closing non transactional SqlSession [org.apache.ibatis.session.defaults.DefaultSqlSession@7a3643e3] [INFO ] 2024-12-02 14:37:20.923 [main] com.ybw.service.TestYearServiceTest - list:[{"id":1,"receiveYear":{"leap":true,"value":2024}}]

源代码

share: 分享仓库 - Gitee.com

4、动态配置

代码实现

/** * sql打印日志 * package命名为mapper方式实现 * * @methodName: configureLoggers * @return: void * @author: ybw * @date: 2024/7/4 **/ @Bean public void configureLoggers() { LoggerContext context = (LoggerContext) LoggerFactory.getILoggerFactory(); Set<String> mapperPackages = findPackagesWithMapper(); if (CollectionUtils.isEmpty(mapperPackages)) { return; } mapperPackages.forEach(packageName -> { // 设置packageName包的日志级别为DEBUG context.getLogger(packageName).setLevel(Level.DEBUG); }); } /** * 扫描包下所有mapper * * @methodName: findPackagesWithMapper * @return: java.util.Set<java.lang.String> * @author: ybw * @date: 2024/7/4 **/ public Set<String> findPackagesWithMapper() { // 使用Spring的PathMatchingResourcePatternResolver来查找资源 PathMatchingResourcePatternResolver resolver = new PathMatchingResourcePatternResolver(); MetadataReaderFactory metadataReaderFactory = new CachingMetadataReaderFactory(resolver); // 示例资源路径,根据实际情况调整 String packageSearchPath = "classpath*:**/" + MybatisPlusConstant.Package.BASE_PACKAGE + "/**/*.class"; try { Resource[] resources = resolver.getResources(packageSearchPath); Set<String> packagesWithMapper = new HashSet<>(); for (Resource resource : resources) { if (resource.isReadable()) { MetadataReader metadataReader = metadataReaderFactory.getMetadataReader(resource); String packageName = ClassUtils.getPackageName(metadataReader.getClassMetadata().getClassName()); if (packageName.contains(MybatisPlusConstant.Package.PACKAGE_KEYWORD)) { packagesWithMapper.add(packageName); } } } return packagesWithMapper; } catch (IOException e) { log.error("findPackagesWithMapper error:", e); } return new HashSet<>(); }

源代码

share: 分享仓库 - Gitee.com

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/10 9:54:55

Mysql ONLY_FULL_GROUP_BY模式详解、group by非查询字段报错

文章目录 一、问题报错二、ONLY_FULL_GROUP_BY模式 2.1、什么是ONLY_FULL_GROUP_BY&#xff1f;2.2、为什么要使用ONLY_FULL_GROUP_BY&#xff1f;2.3、查看sql_mode 三、解决方法 3.1、关闭only_full_group_by模式 3.1.1、方法一&#xff1a;关闭当前会话中的only_full_group…

作者头像 李华
网站建设 2026/6/10 9:56:13

MS SQL Server partition by 函数实战三 成绩排名

目录 需求 范例运行环境 视图样本设计 功能实现 基础数据展示 SQL语句 继续排序 小结 需求 假设有若干已更新考试成绩的考生&#xff0c;考试成绩包括总成绩、分项成绩1、分项成绩2&#xff0c;其它信息包括应聘岗位名称、姓名等信息。现希望根据总成绩计算排名&#…

作者头像 李华
网站建设 2026/6/10 9:57:38

从普通产品经理到AI产品经理,你需要掌握的AI思维与核心技能:AI大模型产品经理从零基础到进阶

AI产品经理与普通产品经理的核心区别在于AI思维。人工智能产业链分为基础层、技术层和应用层。AI产品经理可分为突破型、创新型、应用型和普及型四类&#xff0c;需找准定位&#xff0c;避免常见误区。提升能力需专注目标领域&#xff0c;持续学习&#xff0c;扩大交流圈&#…

作者头像 李华
网站建设 2026/6/10 9:55:00

Thinkphp和Laravel框架的成都某民宿预订系统的设计与实现_r93v34dv

目录摘要项目开发技术介绍PHP核心代码部分展示系统结论源码获取/同行可拿货,招校园代理摘要 本研究基于ThinkPHP和Laravel框架&#xff0c;设计并实现了一款面向成都地区的民宿预订系统。系统采用B/S架构&#xff0c;结合MySQL数据库&#xff0c;旨在为用户提供高效的房源查询…

作者头像 李华
网站建设 2026/6/10 9:51:11

由continue引发的一个debug灾难

整个代码的简化逻辑是这样的&#xff0c;由于continue的使用含义不清楚&#xff0c;导致debug了半天。这里写代码时&#xff0c;错误的将continue认为是else分支&#xff0c;什么也不干&#xff0c;往下继续执行。 但是这样的理解是极其错误的&#xff0c;continue的意思是跳过…

作者头像 李华
网站建设 2026/6/10 9:53:56

knife4j+springboot3.4异常无法正确展示文档

场景复现&#xff1a; knife4j-openapi3-jakarta-spring-boot-starter版本 com.github.xiaoymin knife4j-openapi3-jakarta-spring-boot-starter 4.5.0 原来使用springboot3.3.5版本&#xff0c;先升级到3.4.0版本 通过http://ip:port/doc.html访问接口文档发现访问/v3/api-d…

作者头像 李华