news 2026/4/16 9:26: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/4/16 14:41:28

MCU+AT向OpenCPU转型:技术变革的必然性深度解析(全篇完结)

上一篇在充分理解了OpenCPU的技术优势与架构潜力后&#xff0c;一个现实而关键的问题摆在工程师及企业面前&#xff1a;如何在实际工程中&#xff0c;将现有的MCUAT模组架构&#xff0c;安全、平滑地演进至OpenCPU平台&#xff1f;第六章&#xff1a;迁移与融合策略——从MCUAT…

作者头像 李华
网站建设 2026/4/2 5:11:08

Linux环境下Tomcat的安装与配置详细指南

Apache Tomcat是一个广泛使用的开源Java Servlet容器和Web服务器&#xff0c;适用于运行Java Web应用程序。本指南将详细介绍如何在Linux环境中安装和配置Tomcat&#xff0c;包括必要的前提条件、下载安装、配置环境变量、设置为系统服务以及基本的安全配置。 目录 前提条件安…

作者头像 李华
网站建设 2026/4/16 12:14:30

深度学习计算机毕设之机器学习基于python-CNN的水果识别

博主介绍&#xff1a;✌️码农一枚 &#xff0c;专注于大学生项目实战开发、讲解和毕业&#x1f6a2;文撰写修改等。全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围&#xff1a;&am…

作者头像 李华
网站建设 2026/4/16 13:54:57

Thinkphp和Laravel框架的蛋糕甜品烘焙教程微信小程序设计与实现_6uy1k94r

目录摘要项目开发技术介绍PHP核心代码部分展示系统结论源码获取/同行可拿货,招校园代理摘要 Thinkphp和Laravel框架的蛋糕甜品烘焙教程微信小程序设计与实现&#xff0c;结合了PHP后端框架与微信小程序前端技术&#xff0c;为用户提供便捷的烘焙学习平台。该小程序以蛋糕甜品烘…

作者头像 李华
网站建设 2026/4/16 15:53:41

uvm_config_db机制学习

1. 当uvm_config_db传递一个类的句柄时&#xff0c;传递的是这个句柄&#xff0c;如果有组件在后续的phase中&#xff0c;改变了对象的值&#xff0c;那么其他组件也能感知到这个对象的值发生了变化并不是在build_phase阶段&#xff0c;这个句柄被set了之后&#xff0c;值就不会…

作者头像 李华
网站建设 2026/4/16 14:11:08

uvm_factory机制学习

不仅uvm_component可以用type_id_create&#xff0c;uvm_object类也可以用type_id_create

作者头像 李华