0

我按照本教程开始添加另一个指向单独数据库的持久性单元。它不应该共享阔叶自己的实体。所以...

核心项目现在包含带有这些新 bean 的 applicationContext.xml:

<!-- New data source to our DB -->

<bean id="blMergedDataSources" class="org.springframework.beans.factory.config.MapFactoryBean">
    <property name="sourceMap">
        <map>
            <entry key="jdbc/in1" value-ref="in1DS" />
        </map>
    </property>
</bean>

<bean id="entityManagerFactoryIn1PU"
    class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean">
    <property name="jpaVendorAdapter" ref="blJpaVendorAdapter" />
    <property name="persistenceUnitManager" ref="blPersistenceUnitManager" />
    <property name="persistenceUnitName" value="in1PU" />
</bean>

<bean id="blPersistenceUnitManager" class="org.broadleafcommerce.common.extensibility.jpa.MergePersistenceUnitManager">
    <property name="persistenceXmlLocations">
        <list>
            <value>classpath*:/META-INF/in1_persistence.xml</value>
        </list>
    </property>
    <property name="persistenceUnitPostProcessors">
        <list>
            <bean
                class="org.broadleafcommerce.common.extensibility.jpa.JPAPropertiesPersistenceUnitPostProcessor">
                <property name="persistenceUnitProperties">
                    <map>
                        <entry key="in1PU.hibernate.dialect" value="${in1PU.hibernate.dialect}" />
                        <entry key="in1PU.hibernate.hbm2ddl.auto" value="${in1PU.hibernate.hbm2ddl.auto}"/>
                        <entry key="in1PU.hibernate.show_sql" value="${in1PU.hibernate.show_sql}"/>
                        <entry key="in1PU.hibernate.cache.use_second_level_cache" value="${in1PU.hibernate.cache.use_second_level_cache}"/>
                        <entry key="in1PU.hibernate.cache.use_query_cache" value="${in1PU.hibernate.cache.use_query_cache}"/>
                        <entry key="in1PU.hibernate.hbm2ddl.import_files" value="${in1PU.hibernate.hbm2ddl.import_files}"/>
                        <entry key="in1PU.hibernate.hbm2ddl.import_files_sql_extractor" value="${in1PU.hibernate.hbm2ddl.import_files_sql_extractor}"/>
                    </map>
                </property>
            </bean>
        </list>
    </property>
</bean>

核心项目还有 /META-INF/in1_persistance.xml 文件,其中包含以下内容:

<persistence-unit name="in1PU" transaction-type="RESOURCE_LOCAL">
    <non-jta-data-source>jdbc/in1</non-jta-data-source>    
    <exclude-unlisted-classes/>
</persistence-unit>

此持久性单元的属性与 blPU 的属性非常相似,例如:

in1PU.hibernate.hbm2ddl.auto=create-drop
in1PU.hibernate.dialect=com.in1.hibernate.SubSQLServer2008Dialect

在 admin 中,将新资源添加到 \admin\src\main\webapp\META-INF\context.xml:

<Resource name="jdbc/in1" [....] />

同样在 admin 中,在 \admin\src\main\webapp\WEB-INF\jetty-env.xml 中设置了新的 jndi 资源:

<New id="in1DS" class="org.eclipse.jetty.plus.jndi.Resource">
    <Arg>jdbc/in1</Arg>
    <Arg>
        <New class="org.apache.commons.dbcp.BasicDataSource">
            <Set name="driverClassName">net.sourceforge.jtds.jdbc.Driver</Set>
            <Set name="url">jdbc:jtds:sqlserver://localhost:1433;databaseName=DB2</Set>
            <Set name="username">xyz</Set>
            <Set name="password">xyz</Set>
        </New>
    </Arg>
</New> 

并在 applicationContext-datasource.xml 中添加了以下内容<jee:jndi-lookup id="in1DS" jndi-name="jdbc/in1"/>

应用程序启动并失败并显示以下错误消息:

[artifact:mvn] javax.persistence.PersistenceException: [PersistenceUnit: in1PU] Unable to build EntityManagerFactory
[...]
[artifact:mvn] Caused by: 
[artifact:mvn] org.hibernate.AnnotationException: @OneToOne or @ManyToOne on org.broadleafcommerce.core.catalog.domain.ProductImpl.defaultCategory references an unknown entity: org.broadleafcommerce.core.catalog.domain.CategoryImpl
[artifact:mvn]  at org.hibernate.cfg.ToOneFkSecondPass.doSecondPass(ToOneFkSecondPass.java:109)

我想知道为什么这个新的持久性单元会查找 ProductImpl 类?它没有列出供它使用(在 in1_persistence.xml 中没有列出任何类,并且<exclude-unlisted-classes/>处于打开状态)。它肯定看不到 CategoryImpl 实体......我在这里做错了什么?

4

1 回答 1

1

在调试了 org.hibernate.ejb.Ejb3Configuration 之后,我已经回答了我自己的问题。

在 persistence.xml 中,仅有<exclude-unlisted-classes/>. 该属性hibernate.archive.autodetection也必须设置。基本上它不能为 null。里面的有效值是"class", "hbm"or "class,hbm",这是我们不想要的,因此该值可以设置为任何值,并且"false"做得很好。

所以正确的最小persistence.xml是:

<persistence-unit name="in1PU" transaction-type="RESOURCE_LOCAL">
    <non-jta-data-source>jdbc/in1</non-jta-data-source>    
    <exclude-unlisted-classes/>
    <properties>
        <property name="hibernate.archive.autodetection" value="false" />
    </properties>
</persistence-unit>

希望这可以帮助。

于 2014-01-07T00:44:28.873 回答