问题描述
嗨,团队,
我只是在玩一些东西,所以想和你分享。
我对主键的理解是,Oracle使用唯一索引来强制对表列的主键约束是唯一的。
下面是我尝试的代码,其中我在主键列上创建了非唯一索引,并试图插入重复的数据,但它仍然给出错误。
所以我的问题是Oracle如何强制执行主键约束。
我只是在玩一些东西,所以想和你分享。
我对主键的理解是,Oracle使用唯一索引来强制对表列的主键约束是唯一的。
下面是我尝试的代码,其中我在主键列上创建了非唯一索引,并试图插入重复的数据,但它仍然给出错误。
所以我的问题是Oracle如何强制执行主键约束。
SQL> CREATE TABLE TAB_TEST ( ID NUMBER, NAME VARCHAR2(10) ); Table created. SQL> ALTER TABLE TAB_TEST ADD CONSTRAINT ID_PK PRIMARY KEY (ID) USING INDEX ( CREATE INDEX ID_0P ON TAB_TEST(ID ASC) ); Table altered. SQL> COL INDEX_NAME FOR A10 SQL> COL INDEX_TYPE FOR A10 SQL> COL TABLE_NAME FOR A10 SQL> COL UNIQUENESS FOR A15 SQL> COL STATUS FOR A10 SQL> SELECT INDEX_NAME, INDEX_TYPE, TABLE_NAME, UNIQUENESS, STATUS FROM DBA_INDEXES WHERE TABLE_NAME = 'TAB_TEST'; INDEX_NAME INDEX_TYPE TABLE_NAME UNIQUENESS STATUS ---------- ---------- ---------- --------------- ---------- ID_0P NORMAL TAB_TEST NONUNIQUE VALID SQL> INSERT INTO TAB_TEST VALUES ( 1, 'J1' ); 1 row created. SQL> INSERT INTO TAB_TEST VALUES ( 2, 'J2' ); 1 row created. SQL> INSERT INTO TAB_TEST VALUES ( 3, 'J3' ); 1 row created. SQL> INSERT INTO TAB_TEST VALUES ( 1, 'J1' ); INSERT INTO TAB_TEST VALUES ( 1, 'J1' ) * ERROR at line 1: ORA-00001: unique constraint (FC_DBA1.ID_PK) violated复制
专家解答
我们可以使用非唯一索引来强制执行唯一约束。
这对于可延迟约束是有用的,即,您可以暂时违反它,但数据必须在提交时有效。
这是一篇关于延迟约束的文章
http://www.oracle.com/technetwork/testcontent/o31asktom-354139.html
这对于可延迟约束是有用的,即,您可以暂时违反它,但数据必须在提交时有效。
这是一篇关于延迟约束的文章
http://www.oracle.com/technetwork/testcontent/o31asktom-354139.html
「喜欢这篇文章,您的关注和赞赏是给作者最好的鼓励」
关注作者
【版权声明】本文为墨天轮用户原创内容,转载时必须标注文章的来源(墨天轮),文章链接,文章作者等基本信息,否则作者和墨天轮有权追究责任。如果您发现墨天轮中有涉嫌抄袭或者侵权的内容,欢迎发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。
评论
相关阅读
【专家有话说第五期】在不同年龄段,DBA应该怎样规划自己的职业发展?
墨天轮编辑部
1447次阅读
2025-03-13 11:40:53
Oracle RAC ASM 磁盘组满了,无法扩容怎么在线处理?
Lucifer三思而后行
878次阅读
2025-03-17 11:33:53
RAC 19C 删除+新增节点
gh
539次阅读
2025-03-14 15:44:18
2月“墨力原创作者计划”获奖名单公布
墨天轮编辑部
494次阅读
2025-03-13 14:38:19
Oracle 如何修改 db_unique_name?强迫症福音!
Lucifer三思而后行
425次阅读
2025-03-12 21:27:56
Oracle DataGuard高可用性解决方案详解
孙莹
366次阅读
2025-03-26 23:27:33
墨天轮个人数说知识点合集
JiekeXu
311次阅读
2025-04-01 15:56:03
XTTS跨版本迁移升级方案(11g to 19c RAC for Linux)
zwtian
279次阅读
2025-04-08 09:12:48
风口浪尖!诚通证券扩容采购Oracle 793万...
Roger的数据库专栏
266次阅读
2025-03-24 09:42:53
切换Oracle归档路径后,不能正常删除原归档路径上的归档文件
dbaking
264次阅读
2025-03-19 14:41:51