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

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" 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/
分享到:
评论

相关推荐

    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