為了便于調試、查看生成的SQL,因此我們需要查看Hibernate自動幫我們生成的SQL語句,Hibernate本身自帶了slf4j-1.5.8日志框架(此框架目前好像不是很流行)。訪問log4j官方網站http://logging.apache.org/,去下載JAR包。以下為具體配置方法。

1、將在筆記一里的User Libraries打開,刪除里面的slf4j實現函數包文件slf4j-nop-1.5.8.jar,然后把slf4j-1.5.8文件夾里的slf4j-log4j12-1.5.8.jar包加進來,此包的作用是將slf4j生成的日志轉換成log4j框架的格式,再把apache-log4j-1.2.16文件夾里的log4j-1.2.16.jar包也添加進來(注意包的版本兼容性)。

2、到hibernate-distribution-3.5.6-Final\project\etc目錄里找到log4j.properties(此文件為Logo4j的配置文件,內容如下所示)文件,將此文件復制到項目src文件夾里,到此為止,配置完成。
 1### direct log messages to stdout ###
 2log4j.appender.stdout=org.apache.log4j.ConsoleAppender
 3log4j.appender.stdout.Target=System.out
 4log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
 5log4j.appender.stdout.layout.ConversionPattern=%d{ABSOLUTE} %5p %c{1}:%L - %m%n
 6
 7### direct messages to file hibernate.log ###
 8#log4j.appender.file=org.apache.log4j.FileAppender
 9#log4j.appender.file.File=hibernate.log
10#log4j.appender.file.layout=org.apache.log4j.PatternLayout
11#log4j.appender.file.layout.ConversionPattern=%d{ABSOLUTE} %5p %c{1}:%L - %m%n
12
13### set log levels - for more verbose logging change 'info' to 'debug' ###
14
15log4j.rootLogger=warn, stdout
16
17#log4j.logger.org.hibernate=info
18#log4j.logger.org.hibernate=debug
19
20### log HQL query parser activity
21#log4j.logger.org.hibernate.hql.ast.AST=debug
22
23### log just the SQL
24#log4j.logger.org.hibernate.SQL=debug
25
26### log JDBC bind parameters ###
27#log4j.logger.org.hibernate.type=info
28#log4j.logger.org.hibernate.type=debug
29
30### log schema export/update ###
31log4j.logger.org.hibernate.tool.hbm2ddl=debug
32
33### log HQL parse trees
34#log4j.logger.org.hibernate.hql=debug
35
36### log cache activity ###
37#log4j.logger.org.hibernate.cache=debug
38
39### log transaction activity
40#log4j.logger.org.hibernate.transaction=debug
41
42### log JDBC resource acquisition
43#log4j.logger.org.hibernate.jdbc=debug
44
45### enable the following line if you want to track down connection ###
46### leakages when using DriverManagerConnectionProvider ###
47#log4j.logger.org.hibernate.connection.DriverManagerConnectionProvider=trace
48
具體的參數函數,請參考官方文檔。

3、運行筆記三里的測試用例,log4j格式的日志輸出來了。