mybatis打印带参数sql几种实现方式及优缺点

1. log4jdbc

log4jdbc是google开源的用于专们打印sql日志的工具jar包,使用方法很简单。

第一步:引入maven包,如下:

<dependency>
<groupId>com.googlecode.log4jdbc</groupId>
<artifactId>log4jdbc</artifactId>
<version>1.2</version>
</dependency>

第二步:更改jdbc的驱动名称和连接名称,主要是标红部分:(jdbc.properties)

driverClassName= net.sf.log4jdbc.DriverSpy
jdbcUrl=jdbc:log4jdbc:mysql://192.168.11.11:3306/test?useUnicode=true&characterEncoding=utf8&allowMultiQueries=true&autoReconnect=true&serverTimezone=Asia/Shanghai

第三步:在logback.xml中加入如下配置,各参数说明如下:

<!--
监控sql日志输出
logger 描述
jdbc.sqlonly 仅仅记录 SQL 语句,会将占位符替换为实际的参数
jdbc.sqltiming 包含 SQL 语句实际的执行时间
jdbc.audit 除了 ResultSet 之外的所有JDBC调用信息,篇幅较长
jdbc.resultset 包含 ResultSet 的信息,输出篇幅较长
jdbc.connection 输出了 Connection 的 open、close 等信息
-->
<logger name="jdbc.sqlonly" level="off" additivity="false">
<appender-ref ref="stdoutAppender"/>
</logger>
<logger name="jdbc.resultset" level="off" additivity="false">
<appender-ref ref="stdoutAppender"/>
</logger>
<logger name="jdbc.connection" level="off" additivity="false">
<appender-ref ref="stdoutAppender"/>
</logger>
<logger name="jdbc.sqltiming" level="off" additivity="false">
<appender-ref ref="stdoutAppender"/>
</logger>
<logger name="jdbc.audit" level="off" additivity="false">
<appender-ref ref="stdoutAppender"/>
</logger>

以上三步log4jdbc就配置好了,默认关闭,需要开启时将level级别调至debug即可。

2. mybatis 插件工具

在IDEA 应用商店中下载安装 插件free mybatis plugin即可。

在这里插入图片描述

3. mybatis 拦截器

这个是直接利用mybatis拦截器的特性实现

@Intercepts({ @Signature(type = Executor.class, method = "update", args = { MappedStatement.class, Object.class })})
public class TestExecutorInterceptor implements Interceptor {

private static final Logger logger = LoggerFactory.getLogger(ExecutorInterceptor.class);

@Override
public Object intercept(Invocation arg0) throws Throwable {

Object obj = interceptSqlDuration(arg0);
return obj;
}

/**
* 计算sql执行时长
* @param arg0
* @return
* @throws InvocationTargetException
* @throws IllegalAccessException
*/
private Object interceptSqlDuration(Invocation arg0) throws InvocationTargetException, IllegalAccessException {

MappedStatement mappedStatement = (MappedStatement) arg0.getArgs()[0];
Object parameter = null;
if (arg0.getArgs().length > 1) {
parameter = arg0.getArgs()[1];
}
String sqlId = mappedStatement.getId();
BoundSql boundSql = mappedStatement.getBoundSql(parameter);
Configuration configuration = mappedStatement.getConfiguration();

Object obj = null;
StopWatch watch = new StopWatch();
watch.start();
obj = arg0.proceed();
watch.stop();
String sql = MySql5Hepler.showSql(configuration, boundSql);
logger.debug("\n执行sql:\n{}\n耗时:{}ms",sql, watch.getTotalTimeMillis());
return obj;
}

@Override
public Object plugin(Object arg0) {
return Plugin.wrap(arg0, this);
}

@Override
public void setProperties(Properties properties) {
}

}

以上三种方式,作者推荐使用第一种,后两种插件的方式可能导致打印的参数和实际执行的参数内容不一致

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值