我有项目pf JPA。我的日志如下所示:
Hibernate: insert into TEST(DESCRIPTION, NAME, version, id) values (?, ?, ?, ?)
[08/12/14 06:26:26:026 GET] TRACE sql.BasicBinder: binding parameter [1] as [VARCHAR] - [desc]
[08/12/14 06:26:26:026 GET] TRACE sql.BasicBinder: binding parameter [2] as [VARCHAR] - [name]
[08/12/14 06:26:26:026 GET] TRACE sql.BasicBinder: binding parameter [3] as [INTEGER] - [0]
[08/12/14 06:26:26:026 GET] TRACE sql.BasicBinder: binding parameter [4] as [BIGINT] - [21]
我在log4j配置中有 org.hibernate.type 的跟踪。这很好,但有没有办法编写这种类型的输出?
Hibernate: insert into TEST(DESCRIPTION, NAME, version, id) values (desc, name, 0, 21)
我在谷歌搜索,我无法找到这种类型的解决方案。此输出看起来可读,并且易于读取日志文件。为什么没有这个?
我的配置是这样的:
<category name="org.hibernate.type">
<priority value="trace" />
</category>
答案 0 :(得分:2)
我怀疑这可能是Hibernate开箱即用的。您可以显式代理应用程序创建的连接,语句和预处理语句(使用装饰器设计模式)并记录传递的参数。
答案 1 :(得分:0)
使用slf4j + Log4j
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-log4j12</artifactId>
<version>1.6.1</version> <!-- Use the latest version instead -->
</dependency>
log4j.properties
# Direct log messages to stdout
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.Target=System.out
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=%d{ABSOLUTE} %5p %c{1}:%L - %m%n
# Root logger option
log4j.rootLogger=INFO, file, stdout
# Log everything. Good for troubleshooting
log4j.logger.org.hibernate=INFO
# Log all JDBC parameters
log4j.logger.org.hibernate.type=ALL
的hibernate.cfg.xml
<property name="show_sql">true</property>
现在将记录参数。