我们有一种情况不允许 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/