博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
log4jdbc日志框架-显示sql语句
阅读量:5826 次
发布时间:2019-06-18

本文共 2348 字,大约阅读时间需要 7 分钟。

  hot3.png

现大家使用的ibatis,hibernate,spring jdbc的sql日志信息,有一点个缺点是占位符与参数是分开打印的,如果想要拷贝sql至PLSQL Developer客户端直接执行,需要自己拼凑sql。而log4jdbc是在jdbc层的一个日志框架,可以将占位符与参数全部合并在一起显示,方便直接拷贝sql在PLSQL Developer等客户端直接执行,加快调试速度。

.简单介绍:

1.没有使用log4jdbc前sql显示:

select username,password from bitth_date > ? and age < ? and username = ?

2.使用log4jdbc后sql显示:

select username,password from bitth_date > to_date(‘2010-11-11’,’yyyy-mm-dd’) and age < 20 and username = ‘qq2008’ {executed in 2 msec}

这样就可以直接拷贝上面的sql在PLSQL直接执行. 最后的 {executed in 2 msec} 为SQL执行时间.而如果mysql,日志信息将不会出现 to_date()

.log4jdbc使用:

1.spring xml配置(拦截需要处理的dataSource连接)

 

    
    
       
           
              
log4jdbcInterceptor
                   
              
           
              
dataSource
           
           

2.log4j.properties配置:

log4j.logger.jdbc.sqlonly=OFF

log4j.logger.jdbc.sqltiming=INFO
log4j.logger.jdbc.audit=OFF
log4j.logger.jdbc.resultset=OFF
log4j.logger.jdbc.connection=OFF

(日志信息如果全部为off,log4jdbc将不会生效,因此对性能没有任何影响)

3.下载slf4j

log4jdbc需要依赖slf4j日志框架.

三.扩展说明

DataSourceSpyInterceptor为我自己扩展的一个拦截器类,扩展主要是使用AOP的方式,因为log4jdbc原来的方式不适合我的项目.具体源码为:

import org.aopalliance.intercept.MethodInterceptor;import org.aopalliance.intercept.MethodInvocation;public class DataSourceSpyInterceptor implements MethodInterceptor {private RdbmsSpecifics rdbmsSpecifics = null;    private RdbmsSpecifics getRdbmsSpecifics(Connection conn) {        if(rdbmsSpecifics == null) {            rdbmsSpecifics = DriverSpy.getRdbmsSpecifics(conn);                }                return rdbmsSpecifics;        }    public Object invoke(MethodInvocation invocation) throws Throwable {        Object result = invocation.proceed();        if(SpyLogFactory.getSpyLogDelegator().isJdbcLoggingEnabled()) {            if(result instanceof Connection) {                Connection conn = (Connection)result;                return new ConnectionSpy(conn,getRdbmsSpecifics(conn));            }        }        return result;    }}

四.相关下载:

log4jdbc:

另外一个对log4jdbc的扩展:

本文转载:

<A title=http://blog.sina.com.cn/s/blog_46552dd90100oscb.html href="http://blog.sina.com.cn/s/blog_46552dd90100oscb.html">http://blog.sina.com.cn/s/blog_46552dd90100oscb.html

转载于:https://my.oschina.net/qincd/blog/349496

你可能感兴趣的文章
Cloudera携手CenturyLink提供大数据即服务
查看>>
Eclipse搭建Android ADT+SDK+AVD
查看>>
cengos6.3安装Intel Advanced-N 6205无线驱动
查看>>
redhat 6及centos5.6加载光驱并设置更新源yum
查看>>
P1162 填涂颜色
查看>>
[数据同步] Linux与Windows进行数据同步
查看>>
线性筛欧拉函数
查看>>
Python学习第一周学习总结
查看>>
计算机内存管理相关
查看>>
路由器G口S口对比实验
查看>>
Python基础:数据类型-列表与元组(6)
查看>>
[Jquery] 实现鼠标移到某个对象,在旁边显示层。
查看>>
Linux 目录结构
查看>>
Juniper防火墙MIP配置
查看>>
我的友情链接
查看>>
特征工程(Feature Engineering)
查看>>
Exchange 隐藏联系人在地址列表中显示
查看>>
禁用U盘的四种常规设置方法
查看>>
Zabbix添加自己需要监控的项
查看>>
IPaddr和IPaddr2的区别
查看>>