1

次のように、persistence.xml で 2 つの PU を宣言しました。

<persistence-unit name="myJpaUnit" transaction-type="RESOURCE_LOCAL">
    <provider>org.hibernate.ejb.HibernatePersistence</provider>
    <!-- JPA entities must be registered here -->
    <class>MyUserClass</class>...

<persistence-unit name="anotherJpaUnit" transaction-type="RESOURCE_LOCAL">
    <provider>org.hibernate.ejb.HibernatePersistence</provider>
    <!-- JPA entities must be registered here -->
    <class>MyAnotherClass</class>

    <properties>
        <property name="hibernate.dialect" value="org.hibernate.dialect.PostgreSQLDialect"></property>...

JpaPersistenceModule を次のように構成します。

new IBSJpaRepositoryModule("myJpaUnit", "anotherJpaUnit")

リポジトリ クラスをバインドします。

protected void bindRepositories(RepositoryBinder binder) {
    binder.bind(UserRepository.class).to("myJpaUnit");

    binder.bind(TableauUserRepository.class).to("anotherJpaUnit");
}

リポジトリ クラスは @Transacional で注釈が付けられ、どの PU であるかを宣言します。

@Transactional(value = "myJpaUnit")
public interface UserRepository extends JpaRepository<User, String>, EntityManagerProvider {

}

@Transactional(value = "anotherJpaUnit", readOnly = true)
public interface TableauUserRepository extends JpaRepository<TableauUser, Integer> {

}

「anotherJpaUnit」にマッピングされたエンティティは1つだけで、次のように宣言されています。

@PersistenceContext(unitName="anotherJpaUnit")
@Entity(name = "_user")
@Data
public class TableauUser {
    @Id
    private int id;
    @Column(length = 255)
    private String name;
    @Column(name = "url_namespace", length = 255)
    private String urlNamespace;
    @Column(length = 255)
    private String status;
}

しかし、アプリケーションを起動すると、Guice の初期化でエラーがスローされます。

Caused by: javax.persistence.PersistenceException: [PersistenceUnit: myJpaUnit] Unable to build EntityManagerFactory
at org.hibernate.ejb.Ejb3Configuration.buildEntityManagerFactory(Ejb3Configuration.java:914)
at org.hibernate.ejb.Ejb3Configuration.buildEntityManagerFactory(Ejb3Configuration.java:889)
at org.hibernate.ejb.HibernatePersistence.createContainerEntityManagerFactory(HibernatePersistence.java:73)
at org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean.createNativeEntityManagerFactory(LocalContainerEntityManagerFactoryBean.java:287)
at org.springframework.orm.jpa.AbstractEntityManagerFactoryBean.afterPropertiesSet(AbstractEntityManagerFactoryBean.java:310)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.invokeInitMethods(AbstractAutowireCapableBeanFactory.java:1514)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1452)
... 38 more
Caused by: org.hibernate.HibernateException: Missing table: _user
    at org.hibernate.cfg.Configuration.validateSchema(Configuration.java:1265)

テーブル「_user」は「anotherJpaUnit」にしか存在しないのに、「MyJpaUnit」とバインドしようとするのはなぜですか? ここで何が間違っているのかわかりません。複数の PU が動作する JpaRepositoryModule の例はありますか?

4

1 に答える 1

3

問題が見つかりました。宣言されたクラスのみを考慮するには、persistence.xml で明示する必要があります。すべての @Entity をスキャンしません。正しい persistence.xml 宣言を参照し、タグに注意してください。

<persistence-unit name="tableauJpaUnit" transaction-type="RESOURCE_LOCAL">
    <provider>org.hibernate.ejb.HibernatePersistence</provider>
    <!-- JPA entities must be registered here -->
    <class>MyUserClass</class>
    <exclude-unlisted-classes>true</exclude-unlisted-classes>
    <properties>......
于 2014-09-04T21:45:18.200 に答える