Dre*_*mer 8 sql oracle oracle11g
当SQL Developer导出sql脚本时,有多个选项可用,但无论哪种方式都必须生成UNIQUE INDEX像这样的主键
CREATE UNIQUE INDEX "SYS_C0018099" ON "TRANSACTION" ("ID")
Run Code Online (Sandbox Code Playgroud)
并添加PRIMARY KEY到同一个表和同一列
ALTER TABLE "TRANSACTION" ADD PRIMARY KEY ("ID")
Run Code Online (Sandbox Code Playgroud)
所以问题是:它看起来像冗余吗?我认为在列上创建主键应默认在该列上创建唯一索引?那么为什么第一个命令是必要的呢?
这可能导致数据冗余?
我使用的是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);
Run Code Online (Sandbox Code Playgroud)
因此,它将保留名称(不会创建sysblalbla对象名称),如果使用'USING INDEX'关键字,则可以指定索引属性,例如存储属性.
但同样,这两个语句不会有任何问题,只会创建一个索引.
可能SQL Developer更喜欢为每个对象获取一个ddl,并且可能存在更好的方式.
| 归档时间: |
|
| 查看次数: |
21601 次 |
| 最近记录: |