首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 数据库 > 其他数据库 >

log4jdbc日记框架介绍

2012-06-27 
log4jdbc日志框架介绍现大家使用的ibatis,hibernate,spring jdbc的sql日志信息,有一点个缺点是占位符与参

log4jdbc日志框架介绍
现大家使用的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连接)?

<bean id="log4jdbcInterceptor" />    <bean id="dataSourceLog4jdbcAutoProxyCreator" name="code">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: http://code.google.com/p/log4jdbc/
?另外一个对log4jdbc的扩展: http://code.google.com/p/log4jdbc-remix/

热点排行