一、引言

其实Druid的内置了log4jdbc来显示SQL语句,虽然显示效果不如原生的log4jdbc效果好,但是因为内置所以不需要其他更多的配置。

二、使用

1. 创建基于druid的logger
  1. <bean id="log-filter" class="com.alibaba.druid.filter.logging.Slf4jLogFilter">
  2. <property name="connectionLogEnabled" value="false"/>
  3. <property name="statementLogEnabled" value="false"/>
  4. <property name="resultSetLogEnabled" value="true"/>
  5. <property name="statementExecutableSqlLogEnable" value="true"/>
  6. </bean>
a. resultSetLogEnabled表示是否显示结果集。
b. statementExecutableSqlLogEnable 表示是否显示SQL语句。
2. 在 DruidDataSource中配置
  1. <!-- 数据连接池 -->
  2. <bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource">
  3. .....
  4. <property name="filters" value="stat,wall"/>
  5. ......
  6. <property name="proxyFilters">
  7. <list>
  8. <ref bean="log-filter"/>
  9. </list>
  10. </property>
  11. </bean>
proxyFilters是代理filter的意思,将我们在第一步创建的log-filter写入进去。

三、log4j2中的设置

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- Log4j 2.x 配置文件。每30秒自动检查和应用配置文件的更新; -->
  3. <configuration status="warn" monitorInterval="30" strict="true" schema="Log4J-V2.2.xsd">
  4. <Properties>
  5. <Property name="logdir">${sys:catalina.base}/logs</Property>
  6. </Properties>
  7. <appenders>
  8. <!-- 输出到控制台 -->
  9. <console name="Console" target="SYSTEM_OUT">
  10. <!-- 需要记录的级别 -->
  11. <!-- <ThresholdFilter level="debug" onMatch="ACCEPT" onMismatch="DENY" /> -->
  12. <PatternLayout pattern="%date{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %level [%C{36}.%M] - %msg%n"/>
  13. </console>
  14. <!-- 输出到文件,按天或者超过80MB分割 -->
  15. <rollingFile name="RollingFile" fileName="conerstone.log"
  16. filePattern="${logdir}/logs/$${date:yyyy-MM}/xjj-%d{yyyy-MM-dd}-%i.log.gz">
  17. <!-- 需要记录的级别 -->
  18. <!-- <ThresholdFilter level="info" onMatch="ACCEPT" onMismatch="DENY" /> -->
  19. <PatternLayout pattern="%date{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %level [%C{36}.%M] - %msg%n"/>
  20. <policies>
  21. <onStartupTriggeringPolicy/>
  22. <timeBasedTriggeringPolicy/>
  23. <sizeBasedTriggeringPolicy size="1 MB"/>
  24. </policies>
  25. </rollingFile>
  26. </appenders>
  27. <loggers>
  28. <!-- 全局配置 -->
  29. <root level="info">
  30. <appenderRef ref="Console"/>
  31. <appenderRef ref="RollingFile"/>
  32. </root>
  33. <logger name="org.springframework.web" level="debug" additivity="false">
  34. <appenderRef ref="Console"/>
  35. </logger>
  36. <logger name="com.mc.core.service" level="debug" additivity="false">
  37. <appender-ref ref="Console"/>
  38. </logger>
  39. <!-- druid配置 -->
  40. <logger name="druid.sql.Statement" level="debug" additivity="false">
  41. <appender-ref ref="Console"/>
  42. </logger>
  43. <logger name="druid.sql.ResultSet" level="debug" additivity="false">
  44. <appender-ref ref="Console"/>
  45. </logger>
  46. </loggers>
  47. </configuration>
其中需要特别注意41行之后的代码,表示是否显示sql语句和结果,如果不想显示结果,可以在第一步中将resultSetLogEnabled 改为false

Druid搭配log4j2输出SQL语句和结果的更多相关文章

  1. yii2输出sql语句

    yii2如何输出具体的查询的sql语句: $query = User::find() ->where(['id'=>[1,2,3,4]) ->select(['username']) ...

  2. IBatis.net 输出SQL语句(七)

    一.IBatis.net输出SQL语句到控制台 输出IBatis.net生成的SQL语句到控制台,能够方便调试. 如果要想输出IBatis.net的SQL语句到控制台,那么只需要做如下配置即可: &l ...

  3. NHibernate输出SQL语句

    用了NHierbate之后,很少需要写原生的SQL语句,由于总是看不到SQL语句,所以有时候对SQL调优非常不利.因此产生了让NHibernate输出它所生成的SQL语句的想法,以便于后续调优. 一. ...

  4. Spring3+MyBatis3整合log4j无法输出SQL语句问题的解决

    今天遇到了跟下面文章一模一样的问题,下面文章的解决方案很好,在这里记录保存一下. Spring3+MyBatis3整合无法输出SQL语句问题的解决

  5. Ibatis.Net 输出SQL语句学习(七)

    一.IBatis.net输出SQL语句 输出IBatis.net生成的SQL语句,能够方便调试. 在MapperHelper类中添加GetSql方法: /// <summary> /// ...

  6. Egg上层框架CabloyJS是如何输出SQL语句日志的?

    背景 在Egg开发实践中,经常会遇到一个问题:如何查看刚刚执行过的Egg组装的原生SQL语句呢? 1. 现有方案 可以直接在项目的config配置文件中添加MySQL配置debug: true.这会启 ...

  7. hibernate log4j2输出sql带参数

    网上有很多是输出sql ,参数以?的形式,后面输出参数binding的log,还要自己拼接特别麻烦:这里整理下输出原生sql的方法.组件是log4jdbc 1: 修改pom.xml,确定有下面的配置, ...

  8. 使用Hibernate 拦截执行sql语句,并输出sql语句,获取sql语句

    重建包名 org.hibernate.type.descriptor.sql 重建类BasicBinder 代码如下 package org.hibernate.type.descriptor.sql ...

  9. Hibernate输出SQL语句以便调试

    配置方法:1.打开hibernate.cfg.xml文件编辑界面,在Properties窗口处,点击Add按钮,选择Show_SQL参数,输入值为True. *另外,如果按照同样的步骤,分别加入以下参 ...

随机推荐

  1. Makefile常用万能模板(包括静态链接库、动态链接库、可执行文件)

    本文把makefile 分成了三份:生成可执行文件的makefile,生成静态链接库的makefile,生成动态链接库的makefile. 这些makefile都很简单,一般都是一看就会用,用法也很容 ...

  2. 移动web开发(四)——X-UA-Compatible

    <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1" /> IE=edge告诉 ...

  3. C语言字符串格式化显示

    符号                  作用 ──────────────────────────     %d              十进制有符号整数     %i              输 ...

  4. C#学习笔记(22)——C#创建文本文件txt并追加写入数据

    说明(2017-7-31 16:25:06): 1. 有两种办法,第一种是用FileStream创建txt,用StreamWriter写入数据,期间还要加上判断,是否存在这个txt文件,如果不存在就创 ...

  5. java开发篇---验证码

    验证码的作用:防止恶意破解密码.刷票.论坛灌水.刷页. 有效防止某个黑客对某一个特定注册用户用特定程序暴力破解方式进行不断的登录尝试,实际上使用验证码是现在很多网站通行的方式(比如招商银行的网上个人银 ...

  6. Visual Studio的NuGet包管理器无法加载

    由于网络原因,虽然地址http://www.nuget.org和https://www.nuget.org/api/v2/在浏览器可以正常打开,但是在VS中使用默认的NuGet程序包源经常加载不出来, ...

  7. Go Revel - Filter(过滤器)源码分析

    在 Go Revel - server.go 源码分析 http://www.cnblogs.com/hangxin1940/p/3265538.html 说到revel框架很多重要的东西都Filte ...

  8. jQuery.countdown倒计时插件

    https://github.com/hilios/jQuery.countdown 文档:http://hilios.github.io/jQuery.countdown/documentation ...

  9. 利用python的KMeans和PCA包实现聚类算法

    题目: 通过给出的驾驶员行为数据(trip.csv),对驾驶员不同时段的驾驶类型进行聚类,聚成普通驾驶类型,激进类型和超冷静型3类 . 利用Python的scikit-learn包中的Kmeans算法 ...

  10. Linux中cp直接覆盖不提示的方法

    新做了服务器,cp覆盖时,无论加什么参数-f之类的还是提示是否覆盖,这在大量cp覆盖操作的时候是不能忍受的. 把a目录下的文件复制到b目录 cp –r a/* b 执行上面的命令时,b存在的每个文件都 ...