加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MsSql教程 > 正文

主键和唯一索引 – SQL Developer生成的sql脚本

发布时间:2020-12-12 06:40:20 所属栏目:MsSql教程 来源:网络整理
导读:当SQL Developer导出sql脚本时,有多个选项可用,但无论哪种方式都必须在主键上生成UNIQUE INDEX,如下所示 CREATE UNIQUE INDEX "SYS_C0018099" ON "TRANSACTION" ("ID") 并将PRIMARY KEY添加到同一个表和同一列 ALTER TABLE "TRANSACTION" ADD PRIMARY KEY ("I
当SQL Developer导出sql脚本时,有多个选项可用,但无论哪种方式都必须在主键上生成UNIQUE INDEX,如下所示
CREATE UNIQUE INDEX "SYS_C0018099" ON "TRANSACTION" ("ID")

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

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

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

这可能导致数据冗余?

我使用的是Oracle 11g,所以请分享一下为什么它应该如上所述.

提前致谢.

解决方法

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

第二个命令将使用可用的索引(如果存在).否则(如果第一个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,并且可能存在更好的方式.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读