我有一个带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>
我该如何解决这个问题?
答案 0 :(得分:0)
如果您有自定义修订信息表,则必须将架构指定为 @Table 注释的一部分,即。
@Table(name = "rev", schema = "schema")