Guice JpaRepositoryModule с несколькими единицами сохраняемости

Я объявил свои 2 PU в файле persistence.xml, как показано ниже:

<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», объявленная следующим образом:

@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»? Я не знаю, что я делаю неправильно здесь. У кого-нибудь есть пример JpaRepositoryModule с несколькими работающими PU?


person Gustavo Concon    schedule 04.09.2014    source источник


Ответы (1)


Нашел проблему. Мы должны указать в файле 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>......
person Gustavo Concon    schedule 04.09.2014