news 2026/5/13 6:47:46

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/5/11 6:21:51

10. 同局域网内远程控制另一台电脑

目标&#xff1a; 两台 Windows 家庭版笔记本&#xff0c;在同一 Wi-Fi 下&#xff0c;用 RustDesk 局域网远控 ✅ 不走公网 ✅ 不依赖官方服务器 ✅ 延迟接近本地 ✅ 可扩展到自建服务器一、RustDesk 的“通信模型” 先知道 RustDesk 到底是怎么连的&#xff0c;否则你不知道什…

作者头像 李华
网站建设 2026/5/3 13:41:57

iPerf新手攻略:快速搭建网络测试环境!

搭建网络测试环境是性能评估的第一步&#xff0c;而iPerf因其跨平台兼容性和易用性&#xff0c;成为新手入门的首选工具。无论是Windows、Linux还是macOS&#xff0c;都能快速安装并运行iPerf&#xff0c;完成网络性能测试。本文将手把手教你搭建iPerf测试环境&#xff0c;从服…

作者头像 李华
网站建设 2026/5/3 5:05:08

linux上redis升级

linux上redis升级 redis版本升级。 我原本的redis 版本是6.2.1&#xff0c;现在就对他做一下升级处理。 1、下载redis 源码包&#xff1a; redis 下载地址 根据下载地址选择自己要安装的redis 版本的源码包。这里我下载的是 redis-6.2.6.tar.gz。 这里你可以先下载到本地&am…

作者头像 李华