我花了几天又几天尝试为我的Spring / JPA(Hibernate)集成测试建立一个有效的数据库连接,对神秘的“找不到数据库上下文”错误进行故障排除,但最终使它正常工作,但是我不明白为什么我必须这样做做我做的。
注意我的 LocalContainerEntityManagerFacotryBean 如何引用 HibernateJpaVendorAdapter 。
<bean class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean" id="myEMF"> <property name="persistenceXmlLocation" value="file:src/test/resources/META-INF/persistence.xml" /> <property name="persistenceUnitName" value="myPU" /> <property name="jpaVendorAdapter" ref="hibernateJpaAdapter" /> </bean> <bean id="hibernateJpaAdapter" class="org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter"> <property name="showSql" value="true" /> </bean>
为什么我用这个 HibernateJpaVendorAdapter 时,我的持久性单元已经配置了对Hibernate如下图所示?
<persistence-unit name="myPU" transaction-type="RESOURCE_LOCAL"> <class>com.blah.blah.Class1</class> <class>com.blah.blah.Class2</class> <class>com.blah.blah.Class3</class> <properties> <property name="hibernate.connection.driver_class" value="com.mysql.jdbc.Driver"/> <property name="hibernate.connection.url" value="jdbc:mysql://127.0.0.1?zeroDateTimeBehavior=convertToNull"/> <property name="hibernate.connection.username" value="uname"/> <property name="hibernate.connection.password" value="pwd"/> <property name="hibernate.dialect" value="org.hibernate.dialect.MySQLInnoDBDialect" /> <property name="hibernate.hbm2ddl.auto" value="update" /> <property name="hibernate.show_sql" value="true" /> <property name="hibernate.ejb.event.post-insert" value="org.hibernate.ejb.event.EJB3PostInsertEventListener,org.hibernate.envers.event.AuditEventListener" /> <property name="hibernate.ejb.event.post-update" value="org.hibernate.ejb.event.EJB3PostUpdateEventListener,org.hibernate.envers.event.AuditEventListener" /> <property name="hibernate.ejb.event.post-delete" value="org.hibernate.ejb.event.EJB3PostDeleteEventListener,org.hibernate.envers.event.AuditEventListener" /> <property name="hibernate.ejb.event.pre-collection-update" value="org.hibernate.envers.event.AuditEventListener" /> <property name="hibernate.ejb.event.pre-collection-remove" value="org.hibernate.envers.event.AuditEventListener" /> <property name="hibernate.ejb.event.post-collection-recreate" value="org.hibernate.envers.event.AuditEventListener" /> </properties> </persistence-unit>
似乎可行,但是我这样做正确吗?我可以做另一种/更好的方法吗?
我刚刚在coderanch.com上的帖子中找到了我问题的答案。
如果仅在persistence.xml中的持久性单元定义中指定JPA提供程序,就可以绕开JpaVendorAdapter的使用,如下所示:
<persistence-unit name="myPU" transaction-type="RESOURCE_LOCAL"> <provider>org.hibernate.ejb.HibernatePersistence</provider> . . .