gpt4 book ai didi

sql - 主键和唯一索引——由 SQL Developer 生成的 sql 脚本

转载 作者:行者123 更新时间:2023-12-02 04:17:35 25 4
gpt4 key购买 nike

当通过 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/

更新2:a_horse_with_no_name是正确的,它可以在单个语句中完成,例如:

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

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

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

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

关于sql - 主键和唯一索引——由 SQL Developer 生成的 sql 脚本,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13235099/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com