java - 如何在 Hibernate 不生成任何表的情况下使用 Hibernate Envers (@Audited)

标签 java spring oracle hibernate hibernate-envers

我们有一种情况不允许 Hibernate 创建(重新创建)表。我们将 Hibernate 4.x 与 Spring 结合使用。

我们想通过运行我们自己的带有“AUD”扩展名的 Oracle sql 脚本来手动创建表。

为了简单起见,我有以下类(class)。

@Entity
@Table(name = "ENVERS_TEST")
public class EnversTest {

    @Id
    @Column(name = "ENV_ID")
    @GeneratedValue(strategy = GenerationType.SEQUENCE, generator = "ENVERS_TEST_SEQ")
    @SequenceGenerator(name = "ENVERS_TEST_SEQ", sequenceName = "ENVERS_TEST_SEQ", allocationSize = 1)

    private Integer envId;

    @Audited
    @Column(name = "CREATED_BY")
    private String createdBy;

    @Audited
    @Column(name = "UPDATED_DATE")
    private Date updatedDate;


    @NotAudited
    @Column(name = "DESCR")
    private String description;

    //getters and setters

}

一开始,我设置了另一个数据库模式并使用了

<property name="hibernate.hbm2ddl.auto">create</property>

然后发现下面的sql是自动生成的。

  CREATE TABLE "BDR"."ENVERS_TEST_AUD" 
   (    "ID" NUMBER(10,0) NOT NULL ENABLE, 
"REV" NUMBER(10,0) NOT NULL ENABLE, 
"REVTYPE" NUMBER(3,0), 
"CREATED_BY" VARCHAR2(255 CHAR), 
"UPDATED_DATE" TIMESTAMP (6), 
PRIMARY KEY ("ID", "REV")
  USING INDEX PCTFREE 10 INITRANS 2 MAXTRANS 255 
  TABLESPACE "DBA_DATA1_TS"  ENABLE, 
CONSTRAINT "FK_4637U2YFKSOKDFIXCWWL37ANH" FOREIGN KEY ("REV")
 REFERENCES "BDR"."REVINFO" ("REV") ENABLE
   ) SEGMENT CREATION DEFERRED 
  PCTFREE 10 PCTUSED 40 INITRANS 1 MAXTRANS 255 
 NOCOMPRESS LOGGING
  TABLESPACE "DBA_DATA1_TS" ;

所以我复制了这个 SQL 并尝试在另一个模式上运行,但是行

引用 "BDR"."REVINFO"("REV") 启用

引起问题是因为

REVINFO

不存在。我看到的大多数示例只讨论 AUD 表而不是 REVINFO。这是否意味着还有另一个名为 REVINFO 的表包含时间戳和修订 ID?我找不到这个表的结构。

请告诉我如何手动创建此表。它的结构是什么?

谢谢!

最佳答案

我终于能够创建另一个模式来测试和找到 REVINFO 表 sql 语句。您应该在运行创建基类和 AUD 表的 sql 之前运行此 sql。在这里!!

  CREATE TABLE "REVINFO" 
   (    "REV" NUMBER(10,0) NOT NULL ENABLE, 
"REVTSTMP" NUMBER(19,0), 
PRIMARY KEY ("REV")
  USING INDEX PCTFREE 10 INITRANS 2 MAXTRANS 255 
  TABLESPACE "DBA_DATA1_TS"  ENABLE
   ) SEGMENT CREATION DEFERRED 
  PCTFREE 10 PCTUSED 40 INITRANS 1 MAXTRANS 255 
 NOCOMPRESS LOGGING
  TABLESPACE "DBA_DATA1_TS" ;

问题是我阅读的大部分文档和教程只讨论 _AUD 表而不是 REVINFO 表。

关于java - 如何在 Hibernate 不生成任何表的情况下使用 Hibernate Envers (@Audited),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33308774/

相关文章:

java - Spring 启动 : How to declare a custom repository factory bean

sql - 如何从sqlplus中的表中选择spool的文件名

Oracle 事务隔离

java - 将 int[] 转换为 char[] 无法正常工作

java - 使用 Ajax 刷新页面

java - public static main (String args[]) 的变体

java - 制作主键列 varchar(max) 的替代方法

java - 无法使用资源文件夹中的文件进行 jUnit 测试

.net - 无法为 .NET 中的 Oracle.DataAccess 加载文件或程序集

java - Windows 8 - 退出 Java 应用程序/进程而不停留在后台