news 2026/4/18 4:15:21

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/17 20:50:05

AI 开源知识库大战:WeKnora、RAGFlow、FastGPT、FlashRAG,谁更厉害

我看大家对目前的开源RAG知识库都挺感兴趣的&#xff0c;就像来对比一下目前比较流行的几个知识库&#xff0c;看看哪个更适合你&#xff0c;哪个更有钱途&#xff0c;哈哈。 其实真要搭过这几个知识库&#xff0c;就会发现&#xff1a;每个用到的地方&#xff0c;还真不一样&a…

作者头像 李华
网站建设 2026/4/16 22:44:45

【课程设计/毕业设计】基于python-CNN深度学习的水果识别

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

作者头像 李华
网站建设 2026/4/16 1:47:23

深度学习毕设选题推荐:基于python-CNN的水果识别基于python的水果识别

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

作者头像 李华
网站建设 2026/4/17 23:24:15

Thinkphp和Laravel框架的高校教室报修管理系统_14oaj0v7

目录高校教室报修管理系统摘要项目开发技术介绍PHP核心代码部分展示系统结论源码获取/同行可拿货,招校园代理高校教室报修管理系统摘要 该系统基于ThinkPHP和Laravel框架开发&#xff0c;旨在为高校提供高效的教室设备报修与管理解决方案。通过整合两种框架的优势&#xff0c;…

作者头像 李华
网站建设 2026/4/17 18:04:59

LangChain-08 Query SQL DB 通过GPT自动查询SQL

我们需要下载一个 LangChain 官方提供的本地小数据库。 安装依赖 SQL: https://raw.githubusercontent.com/lerocha/chinook-database/master/ChinookDatabase/DataSources/Chinook_Sqlite.sql Shell: pip install --upgrade --quiet langchain-core langchain-community lang…

作者头像 李华