hibernate envers默认架构不起作用

时间:2014-10-28 09:51:07

标签: hibernate spring-data hibernate-envers

我有一个带maven的项目,我使用了spring数据和JPA(hibernate)。它由XML配置。 envers的默认架构已更改。但它不起作用。当我看到DDL输出时,它说:

  

错误或者是.gerg。   不成功:alter table VETERANS_AUD.USERPROFILE_ROLE_AUD add   约束FK_nbpfx0rjc9hqiaiv4vofp82kc外键(REV)引用   VETERANS_AUD.AuditedRevisionEntity 12:54:37.322   [localhost-startStop-1]错误org.hibernate.tool.hbm2ddl.SchemaUpdate    - ORA-00942:表或视图不存在

问题是:表没有在已定义的模式中创建,但是约束想要在定义的模式中创建。 我使用@AuditTable,但问题已经存在。试镜表不会在定义的架构中创建。

我pom的一部分是:

    <dependency>
        <groupId>org.springframework.data</groupId>
        <artifactId>spring-data-jpa</artifactId>
        <version>1.4.4.RELEASE</version>
    </dependency>
    <dependency>
        <groupId>org.springframework.data</groupId>
        <artifactId>spring-data-envers</artifactId>
        <version>0.2.0.RELEASE</version>
    </dependency>
    <dependency>
    <dependency>
        <groupId>org.hibernate</groupId>
        <artifactId>hibernate-entitymanager</artifactId>
        <version>4.3.6.Final</version>
    </dependency>
    <dependency>
        <groupId>org.hibernate</groupId>
        <artifactId>hibernate-envers</artifactId>
        <version>4.3.6.Final</version>
    </dependency>
    <dependency>

这是我的配置:

<bean id="entityManagerFactory" class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean" p:persistenceXmlLocation="classpath:META-INF/persistence.xml" p:dataSource-ref="dataSource">
        <property name="jpaVendorAdapter">
            <bean class="org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter"  p:databasePlatform="${hibernate.dialect}" p:showSql="${hibernate.show_sql}" p:generateDdl="${hibernate.generate_ddl}" />
        </property>
        <property name="jpaProperties">
            <props>
                <prop key="org.hibernate.envers.default_schema">${hibernate.envers_schema}</prop>
                <prop key="spring.jpa.properties.org.hibernate.envers.default_schema">${hibernate.envers_schema}</prop>
                <prop key="hibernate.hbm2ddl.auto">${hibernate.hbm2ddl.auto}</prop>
                <prop key="hibernate.default_schema">${hibernate.default_schema}</prop>
                <prop key="hibernate.format_sql">${hibernate.format_sql}</prop>
                <prop key="org.hibernate.envers.revision_on_collection_change">false</prop>
                <prop key="hibernate.ejb.naming_strategy">org.hibernate.cfg.DefaultComponentSafeNamingStrategy</prop>
            </props>
        </property>
        <property name="packagesToScan">
            <list>
                <value>com.dpj.veterans.model.domain</value>
                <value>com.juice.applejuice.audition</value>
            </list>
        </property>
    </bean>

我该如何解决这个问题?

1 个答案:

答案 0 :(得分:0)

如果您有自定义修订信息表,则必须将架构指定为 @Table 注释的一部分,即。

@Table(name = "rev", schema = "schema")