0

我正在使用 JPA、Hibernate 和 Sl4j 开发一个应用程序。我可以让我的 sl4j 记录 sql 语句。

这是我的代码:

持久性.xml

<persistence-unit name="timeoffcore.persistence.unit">
    <provider>org.hibernate.jpa.HibernatePersistenceProvider</provider>
    <properties>
        <property name="hibernate.hbm2ddl.auto" value="create"/>
        <property name="show_sql" value="true"/>
    </properties>
</persistence-unit>

log4j.properties

# Direct log messages to a log file
log4j.appender.file=org.apache.log4j.RollingFileAppender
log4j.appender.file.File=timeoff.log
log4j.appender.file.MaxFileSize=1MB
log4j.appender.file.MaxBackupIndex=1
log4j.appender.file.layout=org.apache.log4j.PatternLayout
log4j.appender.file.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss,SSS} %5p %c{1}:%L - %m%n

# 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{yyyy-MM-dd HH:mm:ss,SSS} %5p %c{1}:%L - %m%n

# Root logger option
log4j.rootLogger=INFO, file, stdout

但是日志中没有sql语句。既不在控制台中,也不在文件中。

4

2 回答 2

2

属性名称应为:

  <property name="hibernate.show_sql" value="true" />

persistence.xml

在下面添加条目log4.properties

# Log everything. Good for troubleshooting
log4j.logger.org.hibernate=INFO

# Log all JDBC parameters
log4j.logger.org.hibernate.type=ALL
于 2019-01-05T12:36:02.883 回答
1

可能你应该在 log4j.properties 添加几行

log4j.logger.org.hibernate=INFO
log4j.logger.org.hibernate.SQL=DEBUG
log4j.logger.org.hibernate.type=TRACE

在persistence.xml中还有两行

<property name="format_sql">true</property>
<property name="use_sql_comments">true</property>

我希望它有帮助

于 2019-01-05T12:35:35.793 回答