`
badqiu
  • 浏览: 674484 次
  • 性别: Icon_minigender_1
  • 来自: 珠海
社区版块
存档分类
最新评论

log4jdbc日志框架介绍

    博客分类:
  • Java
阅读更多

 

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

 

.简单介绍:

1.没有使用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直接执行. 最后的 {executed in 2 msec} SQL执行时间.而如果mysql,日志信息将不会出现 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将不会生效,因此对性能没有任何影响)

 

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/

 

 

7
2
分享到:
评论
12 楼 changyuxin 2013-07-09  
yfisaboy 写道
badqiu 写道
yfisaboy 写道
信息: 1. ResultSet.wasNull() returned false
2013-6-20 12:59:38 net.sf.log4jdbc.Slf4jSpyLogDelegator methodReturned
信息: 1. ResultSet.getString(NAME10_0_) returned 企业
2013-6-20 12:59:38 net.sf.log4jdbc.Slf4jSpyLogDelegator methodReturned
信息: 1. ResultSet.wasNull() returned false
2013-6-20 12:59:38 net.sf.log4jdbc.Slf4jSpyLogDelegator methodReturned
信息: 1. ResultSet.getString(SCOPE10_0_) returned 2
2013-6-20 12:59:38 net.sf.log4jdbc.Slf4jSpyLogDelegator methodReturned
信息: 1. ResultSet.wasNull() returned false
2013-6-20 12:59:38 net.sf.log4jdbc.Slf4jSpyLogDelegator methodReturned
信息: 1. ResultSet.getString(STATUS10_0_) returned 1
2013-6-20 12:59:38 net.sf.log4jdbc.Slf4jSpyLogDelegator methodReturned
信息: 1. ResultSet.wasNull() returned false
2013-6-20 12:59:38 net.sf.log4jdbc.Slf4jSpyLogDelegator methodReturned
信息: 1. ResultSet.getTimestamp(STATUS7_10_0_) returned 2013-05-24 10:15:33.0
2013-6-20 12:59:38 net.sf.log4jdbc.Slf4jSpyLogDelegator methodReturned
信息: 1. ResultSet.wasNull() returned false
2013-6-20 12:59:38 net.sf.log4jdbc.Slf4jSpyLogDelegator methodReturned
信息: 1. ResultSet.getInt(USER2_7_1_) returned 24
2013-6-20 12:59:38 net.sf.log4jdbc.Slf4jSpyLogDelegator methodReturned
信息: 1. ResultSet.wasNull() returned false
2013-6-20 12:59:38 net.sf.log4jdbc.Slf4jSpyLogDelegator methodReturned
信息: 1. ResultSet.getInt(ROLE1_1_) returned 1
2013-6-20 12:59:38 net.sf.log4jdbc.Slf4jSpyLogDelegator methodReturned

全是这种的,受不了



你看下官文文档吧,可以通过配置文件控制的。

我是复制文章上的配置,没有起作用

一堆堆的这东西,真烦人,按照log4j里面的配置也不起作用。
11 楼 yfisaboy 2013-07-03  
badqiu 写道
yfisaboy 写道
信息: 1. ResultSet.wasNull() returned false
2013-6-20 12:59:38 net.sf.log4jdbc.Slf4jSpyLogDelegator methodReturned
信息: 1. ResultSet.getString(NAME10_0_) returned 企业
2013-6-20 12:59:38 net.sf.log4jdbc.Slf4jSpyLogDelegator methodReturned
信息: 1. ResultSet.wasNull() returned false
2013-6-20 12:59:38 net.sf.log4jdbc.Slf4jSpyLogDelegator methodReturned
信息: 1. ResultSet.getString(SCOPE10_0_) returned 2
2013-6-20 12:59:38 net.sf.log4jdbc.Slf4jSpyLogDelegator methodReturned
信息: 1. ResultSet.wasNull() returned false
2013-6-20 12:59:38 net.sf.log4jdbc.Slf4jSpyLogDelegator methodReturned
信息: 1. ResultSet.getString(STATUS10_0_) returned 1
2013-6-20 12:59:38 net.sf.log4jdbc.Slf4jSpyLogDelegator methodReturned
信息: 1. ResultSet.wasNull() returned false
2013-6-20 12:59:38 net.sf.log4jdbc.Slf4jSpyLogDelegator methodReturned
信息: 1. ResultSet.getTimestamp(STATUS7_10_0_) returned 2013-05-24 10:15:33.0
2013-6-20 12:59:38 net.sf.log4jdbc.Slf4jSpyLogDelegator methodReturned
信息: 1. ResultSet.wasNull() returned false
2013-6-20 12:59:38 net.sf.log4jdbc.Slf4jSpyLogDelegator methodReturned
信息: 1. ResultSet.getInt(USER2_7_1_) returned 24
2013-6-20 12:59:38 net.sf.log4jdbc.Slf4jSpyLogDelegator methodReturned
信息: 1. ResultSet.wasNull() returned false
2013-6-20 12:59:38 net.sf.log4jdbc.Slf4jSpyLogDelegator methodReturned
信息: 1. ResultSet.getInt(ROLE1_1_) returned 1
2013-6-20 12:59:38 net.sf.log4jdbc.Slf4jSpyLogDelegator methodReturned

全是这种的,受不了



你看下官文文档吧,可以通过配置文件控制的。

我是复制文章上的配置,没有起作用
10 楼 badqiu 2013-06-27  
yfisaboy 写道
信息: 1. ResultSet.wasNull() returned false
2013-6-20 12:59:38 net.sf.log4jdbc.Slf4jSpyLogDelegator methodReturned
信息: 1. ResultSet.getString(NAME10_0_) returned 企业
2013-6-20 12:59:38 net.sf.log4jdbc.Slf4jSpyLogDelegator methodReturned
信息: 1. ResultSet.wasNull() returned false
2013-6-20 12:59:38 net.sf.log4jdbc.Slf4jSpyLogDelegator methodReturned
信息: 1. ResultSet.getString(SCOPE10_0_) returned 2
2013-6-20 12:59:38 net.sf.log4jdbc.Slf4jSpyLogDelegator methodReturned
信息: 1. ResultSet.wasNull() returned false
2013-6-20 12:59:38 net.sf.log4jdbc.Slf4jSpyLogDelegator methodReturned
信息: 1. ResultSet.getString(STATUS10_0_) returned 1
2013-6-20 12:59:38 net.sf.log4jdbc.Slf4jSpyLogDelegator methodReturned
信息: 1. ResultSet.wasNull() returned false
2013-6-20 12:59:38 net.sf.log4jdbc.Slf4jSpyLogDelegator methodReturned
信息: 1. ResultSet.getTimestamp(STATUS7_10_0_) returned 2013-05-24 10:15:33.0
2013-6-20 12:59:38 net.sf.log4jdbc.Slf4jSpyLogDelegator methodReturned
信息: 1. ResultSet.wasNull() returned false
2013-6-20 12:59:38 net.sf.log4jdbc.Slf4jSpyLogDelegator methodReturned
信息: 1. ResultSet.getInt(USER2_7_1_) returned 24
2013-6-20 12:59:38 net.sf.log4jdbc.Slf4jSpyLogDelegator methodReturned
信息: 1. ResultSet.wasNull() returned false
2013-6-20 12:59:38 net.sf.log4jdbc.Slf4jSpyLogDelegator methodReturned
信息: 1. ResultSet.getInt(ROLE1_1_) returned 1
2013-6-20 12:59:38 net.sf.log4jdbc.Slf4jSpyLogDelegator methodReturned

全是这种的,受不了



你看下官文文档吧,可以通过配置文件控制的。
9 楼 yfisaboy 2013-06-20  
信息: 1. ResultSet.wasNull() returned false
2013-6-20 12:59:38 net.sf.log4jdbc.Slf4jSpyLogDelegator methodReturned
信息: 1. ResultSet.getString(NAME10_0_) returned 企业
2013-6-20 12:59:38 net.sf.log4jdbc.Slf4jSpyLogDelegator methodReturned
信息: 1. ResultSet.wasNull() returned false
2013-6-20 12:59:38 net.sf.log4jdbc.Slf4jSpyLogDelegator methodReturned
信息: 1. ResultSet.getString(SCOPE10_0_) returned 2
2013-6-20 12:59:38 net.sf.log4jdbc.Slf4jSpyLogDelegator methodReturned
信息: 1. ResultSet.wasNull() returned false
2013-6-20 12:59:38 net.sf.log4jdbc.Slf4jSpyLogDelegator methodReturned
信息: 1. ResultSet.getString(STATUS10_0_) returned 1
2013-6-20 12:59:38 net.sf.log4jdbc.Slf4jSpyLogDelegator methodReturned
信息: 1. ResultSet.wasNull() returned false
2013-6-20 12:59:38 net.sf.log4jdbc.Slf4jSpyLogDelegator methodReturned
信息: 1. ResultSet.getTimestamp(STATUS7_10_0_) returned 2013-05-24 10:15:33.0
2013-6-20 12:59:38 net.sf.log4jdbc.Slf4jSpyLogDelegator methodReturned
信息: 1. ResultSet.wasNull() returned false
2013-6-20 12:59:38 net.sf.log4jdbc.Slf4jSpyLogDelegator methodReturned
信息: 1. ResultSet.getInt(USER2_7_1_) returned 24
2013-6-20 12:59:38 net.sf.log4jdbc.Slf4jSpyLogDelegator methodReturned
信息: 1. ResultSet.wasNull() returned false
2013-6-20 12:59:38 net.sf.log4jdbc.Slf4jSpyLogDelegator methodReturned
信息: 1. ResultSet.getInt(ROLE1_1_) returned 1
2013-6-20 12:59:38 net.sf.log4jdbc.Slf4jSpyLogDelegator methodReturned

全是这种的,受不了
8 楼 guojch 2012-11-08  
你好,请问用你提供的拦截器模式,还要按照log4jdbc要求的配置方式配dataSource吗?
log4jdbc: 
   
       <bean id="dataSource" 
             class="org.apache.commons.dbcp.BasicDataSource" 
             destroy-method="close"> 
           <property name="driverClassName" value="net.sf.log4jdbc.DriverSpy"/> 
           <property name="url" value="jdbc:log4jdbc:hsqldb:mem:test"/> 
           <property name="username" value="sa"/> 
           <property name="password" value=""/> 
       </bean> 

Original one: 

    <bean id="dataSource" 
          class="org.apache.commons.dbcp.BasicDataSource" 
          destroy-method="close"> 
        <property name="driverClassName" value="org.hsqldb.jdbcDriver"/> 
        <property name="url" value="jdbc:hsqldb:mem:test"/> 
        <property name="username" value="sa"/> 
        <property name="password" value=""/> 
    </bean> 


静待答复,谢谢!
7 楼 haionax 2012-06-02  
melin 写道
借用hibernate sql格式化工具类,把sql格式化一把。这样可以把hibernate.show_sql设置为false。

修改Slf4jSpyLogDelegator类

out.append(sql);
out.append(" {executed in ");
out.append(execTime);
out.append(" msec}");
BasicFormatterImpl format = new BasicFormatterImpl();
return format.format(out.toString());


能否把建表语句也格式化?
6 楼 akandfxs 2012-03-26  
hehe,今天终于找到pomer的升级版了。我打算在pomer的基础上做一个分库的框架的。大体上就是增加一个getHashCode()方法。不过看了rapid,估计在rapid的基础上升级更方便。
sql显示应该在jdbc的driver里面配置就ok了。mysql connector就支持这个功能。
5 楼 badqiu 2011-12-01  
zhuyx808 写道
zhuyx808 写道
老大,你这个东西很好用,
但是就是这个日志的东东会报错。
随便建一个表里面有一个varchar的字段,用框架生成一个demo,然后运行这个demo,插入或修改成一个这样的值:
a'a"
就是先是单引号后是双引号的就会引起错误,异常显示java.util.NoSuchElementException;java.util.StringTokenizer。数据库使用mysql。

具体没深究是哪里引起的问题。


没事的时候看了一眼log4jdbc的源代码,发现了问题所在:
在net.sf.log4jdbc.BasicSqlFormatter.java146行
while ( !"\"".equals( t ) );

应该改为
while ( !"\"".equals( t ) && tokens.hasMoreTokens()  );





这个bug可以报给log4jdbc官方: http://code.google.com/p/log4jdbc/
4 楼 zhuyx808 2011-10-31  
zhuyx808 写道
老大,你这个东西很好用,
但是就是这个日志的东东会报错。
随便建一个表里面有一个varchar的字段,用框架生成一个demo,然后运行这个demo,插入或修改成一个这样的值:
a'a"
就是先是单引号后是双引号的就会引起错误,异常显示java.util.NoSuchElementException;java.util.StringTokenizer。数据库使用mysql。

具体没深究是哪里引起的问题。


没事的时候看了一眼log4jdbc的源代码,发现了问题所在:
在net.sf.log4jdbc.BasicSqlFormatter.java146行
while ( !"\"".equals( t ) );

应该改为
while ( !"\"".equals( t ) && tokens.hasMoreTokens()  );


3 楼 zhuyx808 2011-10-31  
老大,你这个东西很好用,
但是就是这个日志的东东会报错。
随便建一个表里面有一个varchar的字段,用框架生成一个demo,然后运行这个demo,插入或修改成一个这样的值:
a'a"
就是先是单引号后是双引号的就会引起错误,异常显示java.util.NoSuchElementException;java.util.StringTokenizer。数据库使用mysql。

具体没深究是哪里引起的问题。
2 楼 四个石头 2011-04-12  
都是高手,佩服
1 楼 melin 2010-08-20  
借用hibernate sql格式化工具类,把sql格式化一把。这样可以把hibernate.show_sql设置为false。

修改Slf4jSpyLogDelegator类

out.append(sql);
out.append(" {executed in ");
out.append(execTime);
out.append(" msec}");
BasicFormatterImpl format = new BasicFormatterImpl();
return format.format(out.toString());

相关推荐

    log4JDBC全部JAR

    2. **slf4j-api-1.8.0-beta0.jar** 和 **slf4j-log4j12-1.8.0-beta0.jar**:Simple Logging Facade for Java (SLF4J) 是一个用于各种日志框架的抽象层,如Log4j、java.util.logging等。这两个JAR文件分别是SLF4J API...

    使用log4jdbc更有效的记录java sql日志.docx

    Log4jdbc 是一个非常实用的 Java SQL 日志框架,它通过代理模式来拦截常见的 JDBC 驱动,如 Oracle、Derby、MySQL、PostgreSQL、H2、HSQLDB 等,使得开发者能够轻松地记录和分析 SQL 操作。这个框架的核心优势在于其...

    springmvc+mybatis+mysql+log4jdbc+excel 实现sql日志输出和excel导出

    在本项目中,"springmvc+mybatis+mysql+log4jdbc+excel 实现sql日志输出和excel导出",开发者旨在构建一个基于SpringMVC、MyBatis、MySQL数据库,利用Log4jdbc记录SQL日志,并通过Jxls进行Excel数据导出的功能完善的...

    Java实训教程 Java软件开发实战 Java开发框架 log4jdbc 共5页.pptx

    如果启用了JDBC日志记录(`SpyLogFactory.getSpyLogDelegator().isJdbcLoggingEnabled()`返回`true`),并且返回的结果是一个`Connection`对象,则将原始连接包装成`ConnectionSpy`对象并返回。 #### 四、Spring配置...

    SSM整合中的Log4j日志的配置详情

    Log4j 是一个功能强大且广泛使用的日志记录工具,特别是在 SSM(Spring、Spring MVC、Mybatis)整合项目中,合理地配置 Log4j 对项目的日志记录和输出至关重要。本文将详细介绍 SSM 整合中的 Log4j 配置详情,帮助...

    SpringBoot+Spring data JPA+FreeMarker+shiro+log4jdbc

    在开发和性能调优过程中,Log4jdbc能提供宝贵的数据库操作日志,帮助开发者了解数据库性能瓶颈,从而优化数据库查询。 在实际项目中,这些技术的集成通常包括以下步骤: 1. 配置SpringBoot,添加对应的依赖,如...

    log4j2.xml记录日志到到数据库

    Log4j2是一款广泛使用的日志框架,它提供了灵活且高效的日志记录功能。本示例将详细介绍如何配置并使用Log4j2将日志信息记录到MySQL数据库中。 首先,我们要理解Log4j2的核心概念。Log4j2主要包括以下几个组件: 1...

    Log4j 日志信息存储到数据库中

    Apache Log4j 是一个流行的 Java 日志框架,它提供了灵活的日志记录机制,并支持将日志信息存储到不同的目的地,如控制台、文件或数据库等。 本文主要介绍如何使用 Log4j 将日志信息存储到 MySQL 数据库中。通过...

    log4j日志写入数据库实例

    在IT行业中,日志管理是系统监控和故障排查的关键环节,而Log4j作为Java领域广泛应用的日志框架,因其灵活性和高效性深受开发者喜爱。本文将深入探讨如何使用Log4j将日志信息写入数据库,以实现更高级别的日志管理和...

    打log4j日志-ibatis的sql输出

    总结起来,本文介绍了如何结合Log4j和Ibatis来输出SQL日志。通过调整Log4j的配置,开发者可以方便地查看并理解应用程序中的数据库操作,从而提高代码的可维护性和性能。在实际开发中,合理地使用日志记录能够极大地...

    简单java操作log4j+Mysql存储日志信息

    在这个场景中,我们使用了SLF4J(Simple Logging Facade for Java)作为日志抽象层,它为各种日志框架提供了统一的API,而SLF4J-log4j12-1.5.0.jar和slf4j-api-1.5.0.jar正是SLF4J与Log4j之间的桥梁,使得我们可以...

    spring框架和log4j日志用到的jar包

    关于日志,Log4j是一个广泛使用的Java日志框架,它允许开发者记录应用程序运行过程中的事件,提供不同级别的日志输出,如DEBUG、INFO、WARN、ERROR等。Log4j包含配置文件,可以设置日志级别、输出目的地(控制台、...

    如何借助log4j把日志写入数据库中

    Log4j是Apache提供的一款强大的、灵活的日志框架,广泛应用于各种Java应用程序。本文将深入讲解如何利用Log4j将日志信息存储到数据库中。 首先,我们需要理解Log4j的基本架构。Log4j由三个主要组件构成:Logger...

    使用log4j 记录日志到数据库

    Log4j是一款广泛使用的Java日志框架,它允许开发者灵活地控制日志信息的输出。这篇博客“使用log4j记录日志到数据库”将介绍如何配置和使用Log4j,以便将日志信息存储到数据库中,而非传统的文本文件。数据库存储的...

    log4j2 jdbc appender 实现将日志保存到 mysql。

    Log4j2是一款广泛使用的日志记录框架,它提供了丰富的日志处理功能和灵活的配置。JDBC Appender是Log4j2中的一个重要组件,它允许我们把日志信息存储到关系型数据库中,例如MySQL。这个配置尤其适用于需要长期保留和...

    SSM+cxf+log4j整合框架

    5. **Log4j**:Log4j 是一个流行的Java日志框架,提供了一种灵活的日志记录方式。通过配置,开发者可以选择不同的日志级别,控制日志输出的详细程度。在SSM+cxf框架中,Log4j用于记录系统运行时的信息,帮助调试和...

    log4jdbc-1.2-forjdbi:与log4jdbc完全相同,除了它从DEBUG日志语句中删除类和方法信息(因为它与jdbi始终位于同一位置)

    log4jdbc是一个优秀的数据库查询日志工具,而log4jdbc-1.2-forjdbi则是针对JDBI框架的特别定制版。这个版本与原版log4jdbc的主要区别在于,它从DEBUG级别的日志语句中去除了类和方法信息,这主要是因为当log4jdbc与...

    jdbc日志慢SQL过滤工具

    3. **日志收集**:学习如何在应用程序中配置和使用日志框架(如Log4j、SLF4J等),以便记录SQL执行日志。 4. **日志解析**:理解如何从日志文件中提取SQL语句及其执行时间,这通常涉及到正则表达式或特定的日志解析...

Global site tag (gtag.js) - Google Analytics