【问题标题】:Primary Key and Unique Index -- sql scripts generated by SQL Developer主键和唯一索引——SQL Developer生成的sql脚本
【发布时间】:2025-12-08 14:05:01
【问题描述】:

当通过 SQL Developer 导出 sql 脚本时,有多个选项可用,但无论哪种方式都必须像这样在主键上生成 UNIQUE INDEX

CREATE UNIQUE INDEX "SYS_C0018099" ON "TRANSACTION" ("ID") 

并将PRIMARY KEY添加到同一个表和同一列

ALTER TABLE "TRANSACTION" ADD PRIMARY KEY ("ID")

所以问题是:它看起来像是一种冗余吗?我认为在列上创建主键默认情况下也应该在该列上创建唯一索引?那么为什么需要第一个命令呢?

这可能会导致数据冗余?

我使用的是 Oracle 11g,所以请分享任何关于为什么它应该像上面那样的想法。

提前致谢。

【问题讨论】:

标签: sql oracle oracle11g


【解决方案1】:

没有冗余——或者只有一点点:)

第二个命令将使用可用的索引(如果存在)。否则(如果第一个 DDL 不存在)将创建一个索引。

当您为索引指定了正确的名称并希望保留它时,拆分为两个命令很有用。

更新:Thomas Haratyk 指出的链接是必读的,我非常喜欢:http://viralpatel.net/blogs/understanding-primary-keypk-constraint-in-oracle/

UPDATE2:a_horse_with_no_name 是对的,可以在一条语句中完成,例如:

alter table TRANSACTION
add CONSTRAINT pk_test PRIMARY KEY (id);

因此,它将保留名称(不会创建 sysblalbla 对象名称),如果您使用“USING INDEX”关键字,您可以指定索引属性,例如存储属性。

但同样,这两个语句不会有任何问题,只是创建了一个索引。

可能 SQL Developer 更喜欢为每个对象获取一个 ddl,并且在某些情况下它可能会更好。

【讨论】:

  • 感谢英特尔。 @a_horse_with_no_name 您能否给出一个声明作为两者的正式组合 with an index name?我的意思是,我们可以在创建主键时在ALTER TABLE 命令中指定索引名称吗?谢谢
  • @Dreamer: alter table foo add constraint pk_foo primary key (id) 将创建一个名为PK_FOO 的约束和一个同名的索引。如果需要,可以单独定义索引:alter table foo add constraint pk_foo primary key (id) using index (create index pk_index_for_foo on foo(id));
  • @a_horse_with_no_name 为精彩的评论点赞!谢谢 a_horse_with_no_name ;)
最近更新 更多