<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    badqiu

    XPer
    隨筆 - 46, 文章 - 3, 評(píng)論 - 195, 引用 - 0
    數(shù)據(jù)加載中……

    log4jdbc日志框架介紹

     

    現(xiàn)大家使用的ibatis,hibernate,spring jdbc的sql日志信息,有一點(diǎn)個(gè)缺點(diǎn)是占位符與參數(shù)是分開打印,如果想要拷貝sqlPLSQL Developer客戶端直接執(zhí)行,需要自己拼湊sql。而log4jdbc是在jdbc層的一個(gè)日志框架,可以將占位符與參數(shù)全部合并在一起顯示,方便直接拷貝sqlPLSQL Developer等客戶端直接執(zhí)行,加快調(diào)試速度。

    .簡(jiǎn)單介紹:

    1.沒(méi)有使用log4jdbcsql顯示:

     

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

    2.使用log4jdbcsql顯示:

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


    這樣就可以直接拷貝上面的sqlPLSQL直接執(zhí)行. 最后的 {executed in 2 msec} SQL執(zhí)行時(shí)間.而如果mysql,日志信息將不會(huì)出現(xiàn) to_date()

    .log4jdbc使用:

    1.spring xml配置(攔截需要處理的dataSource連接)

        <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配置:

     

    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將不會(huì)生效,因此對(duì)性能沒(méi)有任何影響)

    3.下載slf4j

    log4jdbc需要依賴slf4j日志框架. http://www.slf4j.org/

    三.擴(kuò)展說(shuō)明

    DataSourceSpyInterceptor為我自己擴(kuò)展的一個(gè)攔截器類,擴(kuò)展主要是使用AOP的方式,因?yàn)閘og4jdbc原來(lái)的方式不適合我的項(xiàng)目.具體源碼為:

     

     

    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;
     }
    }

     

    四.相關(guān)下載:

     

    log4jdbc: http://code.google.com/p/log4jdbc/

    另外一個(gè)對(duì)log4jdbc的擴(kuò)展: http://code.google.com/p/log4jdbc-remix/

     

     

    posted on 2010-08-20 14:07 badqiu 閱讀(5307) 評(píng)論(8)  編輯  收藏

    評(píng)論

    # re: log4jdbc日志框架介紹  回復(fù)  更多評(píng)論   

    好東東。。。
    2010-08-20 14:22 | melin

    # re: log4jdbc日志框架介紹  回復(fù)  更多評(píng)論   

    用p6spy也可以解決此問(wèn)題
    2010-08-20 16:08 | cxh8318

    # re: log4jdbc日志框架介紹[未登錄](méi)  回復(fù)  更多評(píng)論   

    不錯(cuò)的東西,剛看了。
    還有cxh8318介紹的P6Spy已經(jīng)是2003年到現(xiàn)在沒(méi)有更新的東西了。
    而現(xiàn)在都是jdbc4了
    2010-08-20 16:39 | alan

    # re: log4jdbc日志框架介紹  回復(fù)  更多評(píng)論   

    借用hibernate sql格式化工具類,把sql格式化一把。這樣可以把hibernate.show_sql設(shè)置為false。

    修改Slf4jSpyLogDelegator類

    out.append(sql);
    out.append(" {executed in ");
    out.append(execTime);
    out.append(" msec}");
    BasicFormatterImpl format = new BasicFormatterImpl();
    return format.format(out.toString());
    2010-08-20 17:05 | melin

    # re: log4jdbc日志框架介紹[未登錄](méi)  回復(fù)  更多評(píng)論   

    melin你太有才了,是個(gè)不錯(cuò)的想法。哈!!!
    2010-08-20 18:14 | badqiu

    # re: log4jdbc日志框架介紹  回復(fù)  更多評(píng)論   

    log4jdbc 在那個(gè)地方可以修改執(zhí)行的sql語(yǔ)句。
    2010-08-22 16:51 | melin

    # re: log4jdbc日志框架介紹[未登錄](méi)  回復(fù)  更多評(píng)論   

    非常好的東東,實(shí)在太感謝了,哥們兒
    2010-08-23 16:42 | Nicholas

    # re: log4jdbc日志框架介紹[未登錄](méi)  回復(fù)  更多評(píng)論   

    非常好,就是下載的時(shí)候 還差一點(diǎn) 就是下不來(lái)
    2013-08-06 19:56 | 歐陽(yáng)

    只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。


    網(wǎng)站導(dǎo)航:
     
    主站蜘蛛池模板: 亚洲av永久无码精品秋霞电影影院| 性xxxxx免费视频播放| 国产人成免费视频| 亚洲综合激情五月色一区| 亚洲AV无码成人精品区在线观看 | 成人免费无码大片A毛片抽搐色欲| 亚洲免费精彩视频在线观看| 日韩免费无码视频一区二区三区| 久久亚洲国产精品| 亚洲av无码专区首页| 日韩在线天堂免费观看| 亚洲1区2区3区精华液| 大胆亚洲人体视频| 亚洲国产精品人久久电影| 国产四虎免费精品视频| 亚洲片国产一区一级在线观看| 国产精品无码永久免费888| 国产成人麻豆亚洲综合无码精品| 亚洲国产成人久久综合| 免费a级黄色毛片| 亚洲精品无码久久久久APP | 亚洲网址在线观看| 免费毛片a在线观看67194| 亚洲av成人一区二区三区在线播放| 亚洲AV无码不卡在线观看下载| a级大片免费观看| 亚洲国产成人a精品不卡在线| 欧洲美女大片免费播放器视频| 1000部啪啪未满十八勿入免费| 亚洲真人无码永久在线| 一区二区在线免费观看| 亚洲大码熟女在线观看| 亚洲线精品一区二区三区影音先锋| 24小时日本韩国高清免费| 亚洲成在人线aⅴ免费毛片| 亚洲人成亚洲人成在线观看| 毛片网站免费在线观看| 黄色视频在线免费观看| 国产成人亚洲综合网站不卡| 国产一卡2卡3卡4卡2021免费观看| 国产精品亚洲精品日韩电影|