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

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/1125597.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

专业的TP公司主要是做什么的呢?

TP&#xff08;Tmall Partner&#xff0c;天猫合作伙伴&#xff09;公司是经天猫等主流电商平台官方认证的专业代运营机构&#xff0c;凭借对平台规则的深度掌控、成熟的运营方法论与丰富的资源储备&#xff0c;成为品牌布局天猫等核心电商渠道的重要战略伙伴。在品牌线上化竞争…

强烈安利8个AI论文网站,MBA论文写作必备!

强烈安利8个AI论文网站&#xff0c;MBA论文写作必备&#xff01; 1.「千笔」—— 一站式学术支持“专家”&#xff0c;从初稿到降重一步到位&#xff08;推荐指数&#xff1a;★★★★★&#xff09;对于MBA学生而言&#xff0c;论文写作不仅是学术能力的体现&#xff0c;更是时…

材料电性能检测仪器的原理、演进与工程应用

材料电性能检测的核心是通过仪器精确测量介电常数&#xff08;ε&#xff09;和介质损耗角正切值&#xff08;tanδ&#xff09;&#xff0c;这些参数直接反映材料的绝缘性能、能量损耗和高频适应性。其原理基于电桥法、谐振法或阻抗法&#xff0c;通过施加交流电场并测量材料的…

第1-2章 数据分析流程及Numpy科学计算

第一章 数据分析流程 数据分析完整流程 数据收集→数据清洗→数据分析→数据可视化 数据分析核心三件套 Numpy Pandas Matplotlib 第二章 Numpy科学计算 Numpy介绍 Python 中科学计算的基础包&#xff0c;提供多维数组对象、各种派生对象&#xff08;掩码数组和矩阵等&#xff…

Linux下安装Nginx服务及systemctl方式管理nginx详情

1.安装依赖包 yum一件安装所需的依赖包 yum -y install gcc zlib zlib-devel pcre-devel openssl openssl-devel 2.下载nginx压缩包 在Nginx官网下载nginx(Index of /download/)&#xff0c;更具自己想要的版本下载相应的tar.gz包 3.创建目录 在Linux环境下创建一个安装目录…

【架构设计】Agentic AI提示工程驱动的个性化推荐系统:微服务拆分策略

Agentic AI提示工程驱动的个性化推荐系统&#xff1a;微服务拆分策略与实践 一、引言&#xff1a;为什么传统推荐系统需要"Agent化"重构&#xff1f; 1. 一个真实的痛点&#xff1a;传统推荐系统的"僵化"困境 假设你是某电商平台的用户&#xff1a; 你最近…

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…

Thinkphp和Laravel框架的西安工商学院学生请假管理系统_s4hrg6g5

目录ThinkPHP与Laravel框架的西安工商学院学生请假管理系统项目开发技术介绍PHP核心代码部分展示系统结论源码获取/同行可拿货,招校园代理ThinkPHP与Laravel框架的西安工商学院学生请假管理系统 该系统基于ThinkPHP或Laravel框架开发&#xff0c;旨在为西安工商学院提供高效的…

小迪安全2023-2024|第13天:信息打点-Web应用源码泄漏开源闭源指纹识别GITSVND_笔记|web安全|渗透测试|网络安全_2023-2024

第13天&#xff1a;信息打点-Web应用&源码泄漏&开源闭源&指纹识别&GIT&SVN&D_笔记 一、信息打点 00:00 1. 业务资产 03:42 1&#xff09;应用类型分类 开源应用: 定义: 指能够从网上直接下载或已公开的程序源码特点: 通常发布在主流源码平台&#xff0…

Linux下启动redis

一、直接启动redis 使用这种启动方式需要一直打开窗口&#xff0c;不能进行其他操作&#xff0c;按 ctrl c可以关闭窗口。 [rootxxx ~]# cd /usr/local/redis-4.0.6/src [rootxxx src]# ./redis-server二、以后台进程形式启动redis ①设置redis.conf中daemonize为yes&#xff…

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

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

一文读懂监督、无监督、自监督与半监督学习:小白到大模型必备知识

文章系统介绍机器学习的四大范式&#xff1a;监督学习依赖标注数据训练模型&#xff1b;无监督学习挖掘数据内在特征完成任务&#xff1b;半监督学习结合少量标注和大量无标签数据提升性能&#xff1b;自监督学习通过设计辅助任务从无标签数据中生成监督信号。这些方法各有特点…

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

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

大模型开发收藏级指南:为什么资深开发者建议先跳过Dify和LangChain?

文章指出&#xff0c;在快速迭代的AI领域&#xff0c;框架往往"约束"大于"赋能"。真正掌握LLM开发应先通过Python调用原生API&#xff0c;以获得更高透明度、更好调试体验和更快适配新特性。建议采用渐进式开发路径&#xff1a;先通过原生API理解基础&…

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

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

由continue引发的一个debug灾难

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

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

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

Thinkphp和Laravel框架的网上购书图书销售商城系统网站的设计与实现_55ap4swk

目录系统设计背景技术架构功能模块性能与安全总结项目开发技术介绍PHP核心代码部分展示系统结论源码获取/同行可拿货,招校园代理系统设计背景 ThinkPHP和Laravel作为国内流行的PHP框架&#xff0c;分别以高效开发与优雅设计著称。网上购书商城系统基于两者实现&#xff0c;旨在…

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

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

Vue 3 中,unmounted 生命周期钩子会在组件实例被销毁并从 DOM 中移除后调用

Vue3中unmounted钩子在组件销毁时触发&#xff0c;常见场景包括&#xff1a;v-if条件变化&#xff1b;动态组件切换&#xff1b;路由导航&#xff1b;v-for列表更新&#xff1b;父组件卸载&#xff1b;手动调用unmount()&#xff1b;Teleport目标移除&#xff1b;组合式API停止…