log4j打印mybatis执行sql,将占位符换成真实的参数输出

背景:

在我日常码代码的时候,由于对mybatis的动态sql,比较依赖,并且有时候需求复杂,导致sql较长,而且参数众多,当出现问题是,需要将sql,放到navicat里面去执行查看结果,但是对于复杂的sql来说,众多的参数,一个一个替换。当真很麻烦,于是萌生出可不可以将sql直接输出,不在出线sql和参数分开的情况,可以减少很多麻烦,在我找度娘,一次又一次的尝试,我还是没有发现,在log4j的配置文件里面。有这个功能,所以最后萌生出改写源码的想法,之后我也会尝试继续寻找,有没有官方的API提供,本文讲述我自己改写源代码实现的方案
一、针对DEMO搭建SSM项目(略)
二、采用的log4j的版本(这里由于log的众多实现,有可能出线log4j的冲突,而且我也没有滤的特别清楚,所以贴出自己使用的log4j的版本,采用maven提供)
			<!-- log4j 日志 -->
			<dependency>
				<groupId>log4j</groupId>
				<artifactId>log4j</artifactId>
				<version>${log4j-version}</version>
			</dependency>


三、首先实现输出mybatis输出sql
1、引入jar包(同上)
2、配置mybatis输出sql的配置项
	<settings>
		<setting name="logImpl" value="LOG4J" />
	</settings>
3、添加logj4j.properties文件
#logFile
log4j.rootLogger=DEBUG,Console
#Console    
log4j.appender.Console=org.apache.log4j.ConsoleAppender  
log4j.appender.console.Threshold=INFO
log4j.appender.console.ImmediateFlush=true
log4j.appender.Console.Target=System.out
log4j.appender.Console.layout=org.apache.log4j.PatternLayout
log4j.appender.Console.layout.ConversionPattern=%-5p %d{yyyy-MM-dd HH:mm:ss}[%t] %l: %x%m%n

# 日志文件(logFile)
log4j.appender.logFile=org.apache.log4j.FileAppender
log4j.appender.logFile.Threshold=DEBUG
# 立即输出
#log4j.appender.logFile.ImmediateFlush=true 
#log4j.appender.logFile.Append=true
#log4j.appender.logFile.File=D:/logs/log.log4j
#log4j.appender.logFile.layout=org.apache.log4j.PatternLayout
#log4j.appender.logFile.layout.ConversionPattern=%-5p %d{yyyy-MM-dd HH:mm:ss}[%t] %l: %x%m%n

log4j.logger.org.apache=ERROR
log4j.logger.org.mybatis=ERROR  
log4j.logger.org.springframework=ERROR  
#这个需要 
log4j.logger.log4jdbc.debug=ERROR  

log4j.logger.jdbc.audit=ERROR
log4j.logger.jdbc.resultset=ERROR  
#这个打印SQL语句非常重要  
log4j.logger.jdbc.sqlonly=DEBUG
log4j.logger.jdbc.sqltiming=ERROR 
log4j.logger.jdbc.connection=FATAL
4、测试结果
==>  Preparing: select u.id as id ,u.name as name , u.pwd as pwd from user u where u.pwd = ? and u.id = ?; 
==> Parameters: 123(String), 1(String)
<==      Total: 0
显然:参数和sql是分离的,现在要实现将参数嵌套进sql中,实现上面的想法

通过源码的分析最后我决定动(org.apache.ibatis.logging.jdbc.BaseJdbcLogger)这个类,它的作用是输出最后的sql

方法步骤:

1、找到这个类的全路径,找到源码
2、在src下创建一个同路径下的BaseJdbcLogger类,并且将源码原封不动的贴近刚创建的类,
3、找到需要修改的方法,我贴一下我准备修改的方法
 protected void debug(String text, boolean input) {
    if (statementLog.isDebugEnabled()) {
      statementLog.debug(prefix(input) + text);
    }
  }
目前的这个是 BaseJdbcLogger.debug的源码,其中(text:是需要打印的文本,input:表示前面的“==>”的方向)
经过我的修改:
  /* 打印的sql */
  private static String sql = "";
  protected void debug(String text, boolean input) {
      text = text.trim();
      if (statementLog.isDebugEnabled()) {
      if(text.startsWith("Preparing:")){
    	  sql = text.substring(text.indexOf(":")+1);
    	  return ;
      }
      if(text.startsWith("Parameters:")){
    	  String temp = text.substring(text.indexOf(":")+1);
    	  String[] split = temp.split(",");
    	  if(split != null & split.length > 0){
    		  for (String string2 : split) {
				String s = string2.trim();
				sql = sql.replaceFirst("\\?", s.substring(0, s.indexOf("(")));
			}
    	  }
    	  text = "Preparing:"+ sql ;
    	  sql = "";
      }
      statementLog.debug(prefix(input) + text);
    }
  }
最终输出结果:
==> Preparing: select u.id as id ,u.name as name , u.pwd as pwd from user u where u.pwd = 123 and u.id = 1;
<== Total: 0
到到最终目的
(虽然不是最好的方法,mybatis应该分装相应的配置,但是我没有发现,如果有码友发现了,请告知我,谢谢)




  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值