Mybatis sql 控制台格式化

package com.mysql;
import org.apache.commons.lang.StringUtils;
import org.apache.ibatis.logging.Log;import java.util.*;/*** @Description: sql 格式化* @Author: DingQiMing* @Date: 2023-07-17* @Version: V1.0*/
public class StdOutImpl implements Log {private static final String PREPARING_KEY = "==>  Preparing: ";private static final String PARAMETERS_KEY = "==> Parameters: ";ThreadLocal<String> threadLocal = new ThreadLocal<>();public StdOutImpl(String clazz) {// Do Nothing}@Overridepublic boolean isDebugEnabled() {return true;}@Overridepublic boolean isTraceEnabled() {return true;}@Overridepublic void error(String s, Throwable e) {System.err.println(s);e.printStackTrace(System.err);}@Overridepublic void error(String s) {System.err.println(s);}@Overridepublic void debug(String s) {System.out.println(s);if (s.startsWith(PREPARING_KEY)) {threadLocal.set(s.replaceAll(PREPARING_KEY, ""));}else if (s.startsWith(PARAMETERS_KEY)) {String sql = threadLocal.get();String params = s.replaceAll(PARAMETERS_KEY, "");String log = this.parseSql(sql,parseParams(params)).toString();System.err.println("==>  Log: " + log);}}@Overridepublic void trace(String s) {System.out.println(s);}@Overridepublic void warn(String s) {System.out.println(s);}private static final char MARK = '?';private static final Set<String> NEED_BRACKETS;static {Set<String> types = new HashSet<>(8);types.add("String");types.add("Date");types.add("Time");types.add("LocalDate");types.add("LocalTime");types.add("LocalDateTime");types.add("BigDecimal");types.add("Timestamp");NEED_BRACKETS = Collections.unmodifiableSet(types);}static StringBuilder parseSql(String sql, Queue<Map.Entry<String, String>> params) {final StringBuilder sb = new StringBuilder(sql);for (int i = 0; i < sb.length(); i++) {if (sb.charAt(i) != MARK) {continue;}final Map.Entry<String, String> entry = params.poll();if (Objects.isNull(entry)) {continue;}sb.deleteCharAt(i);if (NEED_BRACKETS.contains(entry.getValue())) {sb.insert(i, String.format("'%s'", entry.getKey()));} else {sb.insert(i, entry.getKey());}}return sb;}static Queue<Map.Entry<String, String>> parseParams(String line) {line = StringUtils.removeEnd(line, "\n");final String[] strings = StringUtils.splitByWholeSeparator(line, ", ");final Queue<Map.Entry<String, String>> queue = new ArrayDeque<>(strings.length);for (String s : strings) {String value = StringUtils.substringBeforeLast(s, "(");String type = StringUtils.substringBetween(s, "(", ")");if (StringUtils.isEmpty(type)) {queue.offer(new AbstractMap.SimpleEntry<>(value, null));} else {queue.offer(new AbstractMap.SimpleEntry<>(value, type));}}return queue;}
}

修改application.properties文件中

mybatis.configuration.log-impl:com.mysql.StdOutImpl

运行后,结果

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

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

相关文章

别忽视平台的重要性

目录 前言&#xff1a; 与谁在一起&#xff0c;真的很重要 别把运气当才华&#xff0c;别把平台当本事 珍惜平台&#xff0c;用好平台 前言&#xff1a; 对于做技术开发的人来说&#xff0c;一头扎进技术里面去固然重要&#xff0c;但是很多时候&#xff0c;也要看看人际交…

提高安全投资回报:威胁建模和OPEN FAIR™风险分析

对大多数人和企业来说&#xff0c;安全意味着一种成本。但重要的是如何获得适合的量&#xff0c;而不是越多越好。然而&#xff0c;你如何决定什么时候可以有足够的安全性&#xff0c;以及你如何获得它&#xff1f;则完全是另一回事。 该篇文章是由The Open Group安全论坛主办&…

英国伦敦交易所股票清单列表数据API接口

# Restful API https://tsanghi.com/api/fin/stock/XLON/list?token{token}更新时间&#xff1a;收盘后3~4小时。 更新周期&#xff1a;每天。 请求方式&#xff1a;GET。 # 测试&#xff1a;返回不超过10条数据&#xff08;2年历史&#xff09; https://tsanghi.com/api/fin/…

Postman进行Websocket接口测试

Postman进行Websocket接口测试 前言下载地址使用1、new一个一个WebSocket Request2、填写内容和需要请求头携带的参数3、表示成功 网页请求101表示握手成功 前言 有些较低版本postman不支持websocket接口测试&#xff0c;如果根据此文未找到创建websocket接口测试的目录&#…

SQLiteC/C++接口详细介绍之sqlite3类(十二)

返回目录&#xff1a;SQLite—免费开源数据库系列文章目录 上一篇&#xff1a;SQLiteC/C接口详细介绍之sqlite3类&#xff08;十一&#xff09; 下一篇&#xff1a;SQLiteC/C接口详细介绍之sqlite3类&#xff08;十三&#xff09; ​37.sqlite3_load_extension 用于在SQLit…

springboot“爱相连”儿童慈善管理系统的设计与实现

摘要 随着网络科技的不断发展以及人们经济水平的逐步提高&#xff0c;网络技术如今已成为人们生活中不可缺少的一部分&#xff0c;而信息管理系统是通过计算机技术&#xff0c;针对用户需求开发与设计&#xff0c;该技术尤其在各行业领域发挥了巨大的作用&#xff0c;有效地促…

Unity AI Navigation插件快速使用方法

AI Navigation插件使您能够创建能够在游戏世界中智能移动的角色。这些角色利用的是根据场景几何结构自动生成的导航网格。障碍物可以让您在运行时改变角色的导航路径。 演示使用的Unity版本为Tuanjie 1.0.0,团结引擎是Unity中国的引擎研发团队基于Unity 2022 LTS版本为中国开发…

免费阅读篇 | 芒果YOLOv8改进111:注意力机制CBAM:轻量级卷积块注意力模块,无缝集成到任何CNN架构中,开销可以忽略不计

&#x1f4a1;&#x1f680;&#x1f680;&#x1f680;本博客 改进源代码改进 适用于 YOLOv8 按步骤操作运行改进后的代码即可 该专栏完整目录链接&#xff1a; 芒果YOLOv8深度改进教程 该篇博客为免费阅读内容&#xff0c;YOLOv8CBAM改进内容&#x1f680;&#x1f680;&am…

JAVA基础—JVM内存结构基础需知

1.JVM内存结构 JVM内存结构分为5个区域&#xff1a;方法区&#xff0c;虚拟机栈&#xff0c;本地方法栈、堆、程序计数器。 1.方法区&#xff08;Method Area&#xff09;&#xff1a;用于存储类的结构信息、常量、静态变量、即使编译器编译后的代码等数据。方法区也是所有线…

邮件协议(SMTP、POP3、IMAP4)

电子邮件系统 1、概述 &#xff08;1&#xff09;网络电子邮件系统&#xff0c;好处在于价格低廉&#xff0c;速度非常快 &#xff08;2&#xff09;形式多样化&#xff08;文字、图像、声音……&#xff09; 2、电子邮件系统组成部分 用户代理 MUA&#xff08;Mail User …

z1-5输入编码器实验

一. 实验内容 1、制作LED计数电路&#xff0c;输入是编号为1~5的5个开关&#xff0c;输出是5个发光二极管&#xff08;LED&#xff09; 点几号开关&#xff0c;就有几个LED发光。 2、制作一个5位输入3位输出的编码器&#xff0c; 输入的第5位为1&#xff0c;输出就是数字5对应…