log4jdbc打印完整SQL
Posted 做个匠人,修颗匠心
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了log4jdbc打印完整SQL相关的知识,希望对你有一定的参考价值。
一、log4jdbc简单介绍:
log4jdbc是工作在jdbc层的一个日志框架,能够记录SQL及数据库连接执行信息。
一般的SQL日志会把占位符和参数值分开打印,log4jdbc则会记录数据库执行的完整SQL字符串,在数据库应用开发调试阶段非常有用。
log4jdbc具有以下特性:
- 支持JDBC3和JDBC4。
- 支持现有大部分JDBC驱动。
- 易于配置(在大部分情况下,只需要改变驱动类名和jdbc的URL,设置好日志输出级别)。
- 能够自动把SQL变量值加到SQL输出日志中,改进易读性和方便调试。
- 能够快速标识出应用程序中执行比较慢的SQL语句。
- 能够生成SQL连接数信息帮助识别连接池/线程问题。
二、log4jdbc配置方式:
1.依赖配置:
log4jdbc的使用需要依赖于log4j-1.2.17.jar、slf4j-api.jar-1.7.5、slf4j-log4j12-1.7.5.jar,然后下载log4jdbc-1.2.jar包
2.在日志配置文件中定义相关logger对象的输出级别和输出器:
在log4jdbc中定义了以下五个日志对象:
jdbc.sqlonly : 记录系统执行过的sql语句
jdbc.sqltiming : 记录sql执行的时间,可以分析耗时的sql语句
jdbc.audit : 记录除了ResultSet外的所有JDBC调用情况。一般不需要。
jdbc.resultset : 记录返回结果集信息
jdbc.connection: 记录数据库连接和释放信息,可记录当前的数据库连接数,便于诊断连接是否释放。
log4j.logger.jdbc.sqlonly=DEBUG,console
log4j.logger.jdbc.sqltiming=INFO,console
log4j.appender.console=org.apache.log4j.ConsoleAppender
log4j.appender.console.layout=org.apache.log4j.SimpleLayout
3.修改数据库配置文件:
修改前:
修改后:
到此,log4jdbc的配置就全部完成了。
以上是关于log4jdbc打印完整SQL的主要内容,如果未能解决你的问题,请参考以下文章
[hibernate]log4jdbc日志输出完整SQL语句