現你們使用的ibatis,hibernate,spring jdbc的sql日誌信息,有一點個缺點是佔位符與參數是分開打印的,若是想要拷貝sql至PLSQL Developer客戶端直接執行,須要本身拼湊sql。而log4jdbc是在jdbc層的一個日誌框架,能夠將佔位符與參數所有合併在一塊兒顯示,方便直接拷貝sql在PLSQL Developer等客戶端直接執行,加快調試速度。java
一.簡單介紹:mysql
1.沒有使用log4jdbc前sql顯示:spring
select username,password from bitth_date > ? and age < ? and username = ?
2.使用log4jdbc後sql顯示: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鏈接)google
<bean id="log4jdbcInterceptor" class="net.sf.log4jdbc.DataSourceSpyInterceptor" /> <bean id="dataSourceLog4jdbcAutoProxyCreator" class="org.springframework.aop.framework.autoproxy.BeanNameAutoProxyCreator"> <property name="interceptorNames"> <list> <value>log4jdbcInterceptor</value> </list> </property> <property name="beanNames"> <list> <value>dataSource</value> </list> </property> </bean>
2.log4j.properties配置:spa
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將不會生效,所以對性能沒有任何影響)hibernate
3.下載slf4j調試
log4jdbc須要依賴slf4j日誌框架. http://www.slf4j.org/
三.擴展說明
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: http://code.google.com/p/log4jdbc/
另一個對log4jdbc的擴展: http://code.google.com/p/log4jdbc-remix/