当前位置: 首页 > article >正文

告别MyBatis的‘?‘占位符:用p6spy 3.9.1在Spring Boot里打印可直接执行的SQL(附自定义日志格式)

告别MyBatis的?占位符用p6spy 3.9.1在Spring Boot里打印可直接执行的SQL附自定义日志格式调试SQL语句是Java开发中的日常操作但MyBatis和JPA等ORM框架输出的预编译SQL总带着恼人的?占位符。每次排查问题时开发者不得不手动替换参数既浪费时间又容易出错。p6spy 3.9.1正是为解决这一痛点而生——它能将晦涩的预编译语句转换为可直接在数据库客户端执行的完整SQL。1. 为什么需要SQL语句可视化在Spring Boot项目中ORM框架生成的SQL日志通常是这样的SELECT * FROM users WHERE id ? AND status ?这种输出对调试极不友好无法直接执行需要手动替换占位符缺少关键信息执行时间、连接ID等调试要素缺失上下文割裂难以关联同一事务中的多条SQLp6spy通过数据源代理技术在SQL到达真实数据库前进行拦截和格式化。相比原生HikariCP或Druid的监控功能它的优势在于完整的参数替换自动将?替换为实际值执行耗时统计精确到毫秒的性能数据多输出渠道控制台、文件或Slf4j日志系统实际项目中使用p6spy后SQL日志变为[2023-08-20 14:30:45] --- | took 12ms | statement | connection 5 SELECT * FROM users WHERE id 123 AND status ACTIVE;2. Spring Boot集成实战2.1 依赖配置首先在pom.xml中添加p6spy依赖注意排除可能冲突的旧版本dependency groupIdp6spy/groupId artifactIdp6spy/artifactId version3.9.1/version /dependency2.2 数据源改造修改application.yml中的数据库配置spring: datasource: driver-class-name: com.p6spy.engine.spy.P6SpyDriver url: jdbc:p6spy:mysql://localhost:3306/db_name # 原始配置需保留在spy.properties中2.3 核心配置文件在resources/spy.properties中配置基础参数# 启用SQL格式化模块 module.logcom.p6spy.engine.logging.P6LogFactory # 使用控制台输出 appendercom.p6spy.engine.spy.appender.StdoutLogger # 真实数据库驱动 driverlistcom.mysql.cj.jdbc.Driver # 慢SQL阈值(秒) outagedetectiontrue outagedetectioninterval23. 高级格式化技巧3.1 内置格式化方案p6spy提供两种预置格式SingleLineFormat默认基础单行输出CustomLineFormat可配置的模板化输出推荐使用CustomLineFormat并配置logMessageFormatcom.p6spy.engine.spy.appender.CustomLineFormat customLogMessageFormat%(currentTime) | 耗时 %(executionTime)ms | 连接 %(connectionId) | 语句%(sql)3.2 自定义格式化器创建自定义格式化类实现更复杂的日志输出public class CustomSqlFormatter implements MessageFormattingStrategy { Override public String formatMessage(int connectionId, String now, long elapsed, String category, String prepared, String sql) { return String.format(\n[%s] [%dms] %s\n%s;, LocalDateTime.now().format(DateTimeFormatter.ISO_LOCAL_TIME), elapsed, category, sql.replaceAll(\\s, ).trim()); } }然后在配置中指定logMessageFormatcom.your.package.CustomSqlFormatter4. 生产环境最佳实践4.1 性能优化配置# 关闭不必要的信息 excludecategoriesinfo,debug,resultset,batch # 仅记录超过100ms的SQL executionThreshold100 # 异步日志输出需配合Log4j2 appendercom.p6spy.engine.spy.appender.AsyncLogger4.2 多环境策略建议通过Spring Profile实现差异化配置# application-dev.yml p6spy: enabled: true log-level: debug # application-prod.yml p6spy: enabled: false4.3 与Logback集成对于使用SLF4J的项目推荐配置appendercom.p6spy.engine.spy.appender.Slf4JLogger logMessageFormatcom.p6spy.engine.spy.appender.CustomLineFormat customLogMessageFormat[%(executionTime)ms] %(sqlSingleLine)配合logback-spring.xml实现SQL日志单独归档appender nameSQL_APPENDER classch.qos.logback.core.rolling.RollingFileAppender filelogs/sql.log/file filter classch.qos.logback.classic.filter.ThresholdFilter levelDEBUG/level /filter /appender logger namep6spy levelDEBUG additivityfalse appender-ref refSQL_APPENDER/ /logger5. 疑难问题排查问题1SQL日志没有参数替换检查driverlist是否配置了真实驱动确认URL前缀为jdbc:p6spy:问题2性能明显下降启用executionThreshold过滤短耗时SQL考虑使用AsyncLogger异步输出问题3与HikariCP兼容问题# 在spy.properties中添加 deregisterdriverstrue realdatasourceclasscom.zaxxer.hikari.HikariDataSource在最近的一个电商项目中我们通过p6spy发现了多个N1查询问题。其中一个商品列表接口的SQL调用次数从原来的57次降到了3次响应时间从1200ms优化到200ms。关键就在于能直观看到完整SQL执行序列。

相关文章:

告别MyBatis的‘?‘占位符:用p6spy 3.9.1在Spring Boot里打印可直接执行的SQL(附自定义日志格式)

告别MyBatis的?占位符:用p6spy 3.9.1在Spring Boot里打印可直接执行的SQL(附自定义日志格式) 调试SQL语句是Java开发中的日常操作,但MyBatis和JPA等ORM框架输出的预编译SQL总带着恼人的?占位符。每次排查问题时,开发…...

Simulink代码生成实战:如何让参数结构体在C代码里也‘整整齐齐’

Simulink参数结构体工程化实践:从模型到嵌入式代码的无缝衔接 在嵌入式系统开发中,Simulink模型到C代码的转换质量直接影响着最终产品的可靠性和维护成本。当面对包含数百个参数的复杂控制系统时,如何保证生成的代码既保持高可读性又能完美对…...

保姆级教程:在RuoYi-AI里用Ollama跑通本地Llama3模型(附完整配置截图)

零基础实战:RuoYi-AI与Ollama深度整合指南 第一次在本地环境跑通Llama3模型时,那种"不依赖任何云服务"的成就感至今难忘。作为一款开箱即用的AI开发框架,RuoYi-AI与Ollama的组合让本地大模型部署变得前所未有的简单——但魔鬼往往藏…...

避坑指南:在Win10上用VS2019编译ITK 5.2和RTK 2.3,我踩过的那些坑都帮你填平了

避坑指南:在Win10上用VS2019编译ITK 5.2和RTK 2.3,我踩过的那些坑都帮你填平了 医学图像处理开发者常需搭建ITKRTK环境,但官方文档往往只展示理想路径。本文将解剖我在Windows 10VS2019环境中部署ITK 5.2和RTK 2.3时遇到的7类典型故障&#x…...

别再手动算了!用JavaScript/Node.js实现RGB到HEX颜色转换的三种实用方法

别再手动算了!用JavaScript/Node.js实现RGB到HEX颜色转换的三种实用方法 在Web开发中,颜色值的处理无处不在。从动态主题切换、Canvas绘图到CSS-in-JS方案,RGB与HEX颜色格式的转换是开发者经常需要处理的基础操作。手动计算虽然可行&#xff…...

“SpringSource Training Schedule: September 2013”是指2013年9月SpringSource

“SpringSource Training Schedule: September 2013”是指2013年9月SpringSource(后被VMware收购,现相关培训已整合进Pivotal及后续的VMware Tanzu培训体系)发布的官方培训课程安排。该计划曾涵盖Spring Framework、Spring Integration、Spri…...

Spring Security 3.2.0.RC1(Release Candidate 1)是 Spring Security 框架在 2013 年底发布的候选版本

Spring Security 3.2.0.RC1(Release Candidate 1)是 Spring Security 框架在 2013 年底发布的候选版本,标志着 3.2.x 系列的初步稳定。该版本引入了多项重要改进与新特性,包括: Java Config 支持增强:进一步…...

“Community-Driven Spring Integration Extensions”(社区驱动的 Spring Integration 扩展)是指由 Spring 社区

“Community-Driven Spring Integration Extensions”(社区驱动的 Spring Integration 扩展)是指由 Spring 社区(而非 Spring 官方核心团队)开发、维护和贡献的一系列补充性模块,用于增强 Spring Integration 的功能边…...

“Spring Data release train reaches RC station” 是 Spring 官方常用的一种拟人化表达

“Spring Data release train reaches RC station” 是 Spring 官方常用的一种拟人化表达,意指 Spring Data 的某个版本发布周期(Release Train)已进入 Release Candidate(RC)阶段,即“候选发布版”。这表示…...

“Video: Managing and Monitoring Spring Integration Applications”很可能是指关于如何对基于 Spring Integration 的企业集

“Video: Managing and Monitoring Spring Integration Applications”很可能是指关于如何对基于 Spring Integration 的企业集成应用进行运行时管理与监控的教学视频(例如来自 Spring 官方、SpringOne 大会、Baeldung、YouTube 技术频道或 Pluralsight 等平台的内容…...

虚拟机安装Ubuntu 24.04.x及其常用软件(2026.4)

此次更新把安卓模拟器,烧录工具,无效软件,以及收费软件等不常用软件去除,另外更新了一些下载链接,删除了一些和配置无关的图片。 目录 1 系统安装篇 1.1 安装VMWare Workstation Pro 1.2 下载Ubuntu 24.04.x安装镜…...

Linux 了解硬件体系结构和操作系统内核的管理

目录 冯诺依曼体系结构 操作系统 系统调用接口 进程 启动进程的两种方式:手动启动和代码启动 冯诺依曼体系结构 冯诺依曼结果就是计算机硬件体系结构,硬件主要由五大单元组成: 我们主要讲这五大单元中的存储: 其中存储器就是…...

Open UI5 源代码解析之1104:MenuItem.js

源代码仓库: https://github.com/SAP/openui5 源代码位置:src\sap.ui.commons\src\sap\ui\commons\MenuItem.js MenuItem.js 文件深度分析 文件的直观定位 MenuItem.js 是一个体量非常小的文件,但它在 openui5 这样的大型项目里并不轻。原因在于,它不是靠大段业务逻辑…...

计算机常用英文词汇概念解释

目录 1、property与attribute 2、run、execute与perform 3、option、item、menu、context menu 4、configuration、setting 5、parameter与 argument 6、function、feature 7、command line 8、terminal与console 9、shell ... 计算机常用英文词汇概念解释 伴随着计算机的诞生和…...

电子元件知识汇总4-采购与真伪识别

目录: 一、电阻R 二、电容C 1、钽电容 三、电感L 四、二极管D 1、MB10M、MB10S与MB10F 2、ES2A THRU ES2M 3、KBJ3510、GBJ3510 五、三极管与场效益管Q 1、PBSS4160DPN三极管...

如何快速上手FlashDB:5分钟学会嵌入式数据存储

如何快速上手FlashDB:5分钟学会嵌入式数据存储 【免费下载链接】FlashDB An ultra-lightweight database that supports key-value and time series data | 一款支持 KV 数据和时序数据的超轻量级数据库 项目地址: https://gitcode.com/gh_mirrors/fl/FlashDB …...

SSD硬盘对HTML工具速度有影响吗_存储介质与开发效率关系【详解】

SSD显著提升HTML开发效率:启动快4.6秒、热重载快750ms、构建快24.7秒、DevTools加载快11.8秒,因SSD在随机读写、I/O延迟和吞吐量上远超HDD。如果您在使用HTML开发工具时发现页面加载、文件保存或构建过程响应迟缓,则可能是存储介质的读写性能…...

tabula-py错误处理大全:解决10个最常见的表格提取问题

tabula-py错误处理大全:解决10个最常见的表格提取问题 【免费下载链接】tabula-py Simple wrapper of tabula-java: extract table from PDF into pandas DataFrame 项目地址: https://gitcode.com/gh_mirrors/ta/tabula-py 在处理PDF表格数据时,…...

Android Studio中文插件终极指南:3步搞定界面汉化,开发效率翻倍!

Android Studio中文插件终极指南:3步搞定界面汉化,开发效率翻倍! 【免费下载链接】AndroidStudioChineseLanguagePack AndroidStudio中文插件(官方修改版本) 项目地址: https://gitcode.com/gh_mirrors/an/AndroidStudioChinese…...

为什么宝塔面板误删网站数据库无法通过回收站恢复_需依赖面板先前的定时备份或底层数据快照

不能恢复,除非是通过宝塔数据库页面点击【删除】按钮操作的;其他方式如命令行、phpMyAdmin、API调用或站点删除时勾选删库均不进入回收站,且需满足回收站启用、未超保留期、/www/.Recycle目录权限正常三个前提。不能恢复,除非你删…...

终极 HashiCorp Otto 项目常见问题解决方案:从安装到部署的完整指南

终极 HashiCorp Otto 项目常见问题解决方案:从安装到部署的完整指南 【免费下载链接】otto Development and deployment made easy. 项目地址: https://gitcode.com/gh_mirrors/otto/otto HashiCorp Otto 是一款致力于简化开发和部署流程的强大工具&#xff…...

/usr/bin/ssh-copy-id: ERROR: no identities found 解决方案

大家好,我是爱编程的喵喵。双985硕士毕业,现担任全栈工程师一职,热衷于将数据思维应用到工作与生活中。从事机器学习以及相关的前后端开发工作。曾在阿里云、科大讯飞、CCF等比赛获得多次Top名次。现为CSDN博客专家、人工智能领域优质创作者。喜欢通过博客创作的方式对所学的…...

题解:洛谷 AT_abc389_d [ABC389D] Squares in Circle

本文分享的必刷题目是从蓝桥云课、洛谷、AcWing等知名刷题平台精心挑选而来,并结合各平台提供的算法标签和难度等级进行了系统分类。题目涵盖了从基础到进阶的多种算法和数据结构,旨在为不同阶段的编程学习者提供一条清晰、平稳的学习提升路径。 欢迎大家订阅我的专栏:算法…...

题解:洛谷 AT_abc389_c [ABC389C] Snake Queue

本文分享的必刷题目是从蓝桥云课、洛谷、AcWing等知名刷题平台精心挑选而来,并结合各平台提供的算法标签和难度等级进行了系统分类。题目涵盖了从基础到进阶的多种算法和数据结构,旨在为不同阶段的编程学习者提供一条清晰、平稳的学习提升路径。 欢迎大家订阅我的专栏:算法…...

Production Rails扩展架构设计:如何从单体应用到分布式系统的平滑演进

Production Rails扩展架构设计:如何从单体应用到分布式系统的平滑演进 【免费下载链接】production_rails Best practices for running Rails in production 项目地址: https://gitcode.com/gh_mirrors/pr/production_rails 在现代Web应用开发中,…...

Windows 11下ROS2 Humble与PyCharm环境搭建全攻略(附常见错误解决方案)

Windows 11下ROS2 Humble与PyCharm环境搭建全攻略(附常见错误解决方案) 在机器人操作系统(ROS)生态中,Windows平台的支持一直是个痛点。随着ROS2 Humble版本的发布,微软与开源社区的深度合作为Windows开发者…...

XStream安全机制详解:从ForbiddenClassException看Java反序列化安全最佳实践

XStream安全机制深度解析:构建坚不可摧的Java反序列化防线 当XML数据流经XStream转换器时,一个未被妥善处理的类引用可能成为整个系统的阿喀琉斯之踵。2019年某知名电商平台因反序列化漏洞导致千万级用户数据泄露的案例,至今仍是Java开发者心…...

Ubuntu 24.04 安装后做什么?必装软件、使用技巧与系统优化指南

本文同步发布在个人博客 Ubuntu 24.04 安装后如何开荒?2026年必装软件、使用技巧与系统优化指南 之前本人完成了 Ubuntu 24.04 与 Windows 11 双系统的安装。本指南将手把手教你完成新系统部署后的关键配置,涵盖:系统级优化、Linux 生态必备…...

题解:洛谷 P5854 【模板】笛卡尔树

本文分享的必刷题目是从蓝桥云课、洛谷、AcWing等知名刷题平台精心挑选而来,并结合各平台提供的算法标签和难度等级进行了系统分类。题目涵盖了从基础到进阶的多种算法和数据结构,旨在为不同阶段的编程学习者提供一条清晰、平稳的学习提升路径。 欢迎大家订阅我的专栏:算法…...

终极指南:如何安全处理跨源链接的noopener最佳实践

终极指南:如何安全处理跨源链接的noopener最佳实践 【免费下载链接】developer.chrome.com The frontend, backend, and content source code for developer.chrome.com 项目地址: https://gitcode.com/gh_mirrors/de/developer.chrome.com 在Web开发中&…...