我们有一种情况,我们不允许Hibernate创建(重新创建)表。我们在Spring中使用Hibernate 4.x。
我们希望通过使用" AUD"运行我们自己的Oracle sql脚本来手动创建表。延期。
为简单起见,我有以下课程。
@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并尝试在另一个模式上运行,但行
参考文献&#34; BDR&#34;。&#34; REVINFO&#34; (&#34; REV&#34;)ENABLE
导致问题,因为
REVINFO
不存在。我看到的大多数例子只讨论AUD表而不是REVINFO
。这是否意味着还有另一个名为REVINFO
的表,其中包含时间戳和修订版ID?我无法找到这张桌子的结构。
请告诉我们如何手动创建此表格。它的结构是什么?
谢谢!
答案 0 :(得分:0)
我终于能够创建另一个模式来测试并找到REVINFO表的sql语句。您应该在运行sql之前运行此sql以创建基类和AUD表。这是!!
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表。