log4j2如何输出hibernate执行的sql语句?
问题描述
原先有一个SSH项目使用log4j管理日志,现在需要升级为log4j2,但是一直无法输出hibernate执行的sql语句到日志文件中。
问题出现的环境背景及自己尝试过哪些方法
项目使用SSH框架
现在使用hibernate的配置<prop key="hibernate.show_sql">true</prop>可以将sql语句输出到控制台
网上找到过配置但是无效
<!-- 打印sql语句 -->
<Logger name="org.hibernate.SQL" level="debug" additivity="false">
<AppenderRef ref="console" />
</Logger>
<!-- 打印sql语句的参数绑定 -->
<Logger name="org.hibernate.type.descriptor.sql.BasicBinder" level="trace" additivity="false">
<AppenderRef ref="console" />
</Logger>
相关代码
log4j2配置文件
<?xml version="1.0" encoding="UTF-8"?>
<!-- log4j2 配置文件 -->
<!-- 日志级别 trace<debug<info<warn<error<fatal -->
<configuration status="debug">
<!-- 自定义属性 -->
<Properties>
<!-- 日志格式 -->
<Property name="pattern">%d{yyyy-MM-dd HH:mm:ss,SSS} (%F:%L) %5p %m%n</Property>
<!-- 日志文件路径 -->
<Property name="filePath">D:/Tomcat 6.0/log4j/demo/</Property>
<!-- debug级别日志文件名称 -->
<Property name="debugFileName">${filePath}/debug.log</Property>
<!-- info级别日志文件名称 -->
<Property name="infoFileName">${filePath}/info.log</Property>
<!-- error级别日志文件名称 -->
<Property name="errorFileName">${filePath}/error.log</Property>
</Properties>
<!-- 定义输出器 -->
<appenders>
<!-- 控制台输出 -->
<Console name="console" target="SYSTEM_OUT">
<!-- 日志格式 -->
<PatternLayout pattern="${pattern}"/>
</Console>
<!-- debug级别日志文件输出 -->
<RollingFile name="debug_appender" fileName="${debugFileName}"
filePattern="${filePath}/%d{yyyy-MM-dd}/debug_%i.log">
<!-- 过滤器 -->
<Filters>
<!-- 限制日志级别在debug及以上在info以下 -->
<ThresholdFilter level="debug"/>
<ThresholdFilter level="info" onMatch="DENY" onMismatch="NEUTRAL"/>
</Filters>
<!-- 日志格式 -->
<PatternLayout pattern="${pattern}"/>
<!-- 策略 -->
<Policies>
<!-- 每隔一天转存 -->
<TimeBasedTriggeringPolicy interval="1" modulate="true"/>
<!-- 文件大小 -->
<SizeBasedTriggeringPolicy size="100 MB"/>
</Policies>
</RollingFile>
<!-- info级别日志文件输出 -->
<RollingFile name="info_appender" fileName="${infoFileName}"
filePattern="${filePath}/%d{yyyy-MM-dd}/info_%i.log">
<!-- 过滤器 -->
<Filters>
<!-- 限制日志级别在info及以上在error以下 -->
<ThresholdFilter level="info"/>
<ThresholdFilter level="error" onMatch="DENY" onMismatch="NEUTRAL"/>
</Filters>
<!-- 日志格式 -->
<PatternLayout pattern="${pattern}"/>
<!-- 策略 -->
<Policies>
<!-- 每隔一天转存 -->
<TimeBasedTriggeringPolicy interval="1" modulate="true"/>
<!-- 文件大小 -->
<SizeBasedTriggeringPolicy size="100 MB"/>
</Policies>
</RollingFile>
<!-- error级别日志文件输出 -->
<RollingFile name="error_appender" fileName="${errorFileName}"
filePattern="${filePath}/%d{yyyy-MM-dd}/error_%i.log">
<!-- 过滤器 -->
<Filters>
<!-- 限制日志级别在error及以上 -->
<ThresholdFilter level="error"/>
</Filters>
<!-- 日志格式 -->
<PatternLayout pattern="${pattern}"/>
<Policies>
<!-- 每隔一天转存 -->
<TimeBasedTriggeringPolicy interval="1" modulate="true"/>
<!-- 文件大小 -->
<SizeBasedTriggeringPolicy size="100 MB"/>
</Policies>
</RollingFile>
</appenders>
<!-- 定义logger -->
<loggers>
<!-- 定义根logger -->
<!-- 日志级别设备为debug 具体日志级别由appender限制 -->
<Root level="debug">
<!-- 输出控制台 -->
<AppenderRef ref="console"/>
<!-- 输出debug级别日志文件 -->
<AppenderRef ref="debug_appender"/>
<!-- 输出info级别日志文件 -->
<AppenderRef ref="info_appender"/>
<!-- 输出error级别日志文件 -->
<AppenderRef ref="error_appender"/>
</Root>
</loggers>
</configuration>
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
试试加这个配置: