我正在使用 Maven 3.0.3、SPring 3.1.1.RELEASE、Hibernate 4.1.0.Final 和 log4j 1.2.15。在我的 Maven 项目中,我在 src/test/resources 中有这个 log4j.xml 文件
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE log4j:configuration SYSTEM "log4j.dtd">
<log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/" debug="false">
<appender name="consoleAppender" class="org.apache.log4j.ConsoleAppender">
<layout class="org.apache.log4j.PatternLayout">
<param name="ConversionPattern" value="[%p]: %c - %m%n" />
</layout>
</appender>
<logger name="org.mainco.subco">
<level value="debug" />
</logger>
<logger name="log4j.logger.org.hibernate.SQL">
<level value="DEBUG" />
</logger>
<logger name="log4j.logger.org.hibernate.type">
<level value="TRACE" />
</logger>
<root>
<priority value ="info" />
<appender-ref ref="consoleAppender"/>
</root>
</log4j:configuration>
我的数据源在我的测试应用程序上下文中配置如下:
<bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
<property name="driverClassName" value="${test.mysql.dataSource.driverClassName}" />
<property name="url" value="${test.mysql.dataSource.url}" />
<property name="username" value="${test.mysql.db.user}" />
<property name="password" value="${test.mysql.db.password}" />
</bean>
<bean id="entityManagerFactory" class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean">
<property name="packagesToScan" value="org.mainco.subco" />
<property name="jpaVendorAdapter">
<bean class="org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter"/>
</property>
<property name="dataSource" ref="dataSource"/>
<property name="jpaPropertyMap" ref="jpaPropertyMap" />
</bean>
<util:map id="jpaPropertyMap">
<entry key="hibernate.show_sql" value="true" />
<entry key="dialect" value="org.hibernate.dialect.MySQL5InnoDBDialect" />
<entry key="hibernate.cache.region.factory_class" value="org.hibernate.cache.ehcache.EhCacheRegionFactory"/>
<entry key="hibernate.cache.provider_class" value="org.hibernate.cache.EhCacheProvider"/>
<entry key="hibernate.cache.use_second_level_cache" value="true" />
<entry key="hibernate.cache.use_query_cache" value="false" />
<entry key="hibernate.generate_statistics" value="true" />
</util:map>
但是,当我运行 JUnit 测试时,虽然显示了 SQL,但绑定到 SQL 的参数却没有。如何更改上述任何内容以使绑定参数通过 System.out(或控制台)显示?- 戴夫