【Foreign Key】Oracle外键约束三种删除行为

简介: Oracle使用外键来限制子表中参考的字段值,要求子表中的数据必须在主表中存在。当主表的记录发生变化时导致外键参考唯一约束值发生了变化时,Oracle指定了三种动作:默认值(类似于restrict)、delete cascade和delete set null。
Oracle使用外键来限制子表中参考的字段值,要求子表中的数据必须在主表中存在。当主表的记录发生变化时导致外键参考唯一约束值发生了变化时,Oracle指定了三种动作:默认值(类似于restrict)、delete cascade和delete set null。
实际体验一下他们对删除操作的不同效果。

1.创建主表及子表并简单初始化几条数据
1)创建主表t_parent,并初始化三条记录
sec@ora10g> create table t_parent (parent_id int primary key, name varchar2(10));
sec@ora10g> insert into t_parent values (1,'record1');
sec@ora10g> insert into t_parent values (2,'record2');
sec@ora10g> insert into t_parent values (3,'record3');
sec@ora10g> commit;

2)创建三种类型的子表t_child1、t_child2和t_child3
(1)no action类型
sec@ora10g> create table t_child1 (child1_id int primary key, parent_id int);
sec@ora10g> alter table t_child1 add constraint FK_t_child1 foreign key (parent_id) references t_parent (parent_id);
sec@ora10g> insert into t_child1 values (1,1);
sec@ora10g> commit;
(1)cascade类型
sec@ora10g> create table t_child2 (child2_id int primary key, parent_id int);
sec@ora10g> alter table t_child2 add constraint FK_t_child2 foreign key (parent_id) references t_parent (parent_id) on delete cascade;
sec@ora10g> insert into t_child2 values (2,2);
sec@ora10g> commit;
(1)set null类型
sec@ora10g> create table t_child3 (child2_id int primary key, parent_id int);
sec@ora10g> alter table t_child3 add constraint FK_t_child3 foreign key (parent_id) references t_parent (parent_id) on delete set null;
sec@ora10g> insert into t_child3 values (3,3);
sec@ora10g> commit;

2.确认主表和子表中的数据
sec@ora10g> select * from T_PARENT;

 PARENT_ID NAME
---------- ------------------------------
         1 record1
         2 record2
         3 record3

sec@ora10g> select * from T_CHILD1;

 CHILD1_ID  PARENT_ID
---------- ----------
         1          1

sec@ora10g> select * from T_CHILD2;

 CHILD2_ID  PARENT_ID
---------- ----------
         2          2

sec@ora10g> select * from T_CHILD3;

 CHILD2_ID  PARENT_ID
---------- ----------
         3          3

3.尝试对具有默认类型外键参照的主表记录进行删除
sec@ora10g> delete from T_PARENT where parent_id = 1;
delete from T_PARENT where parent_id = 1
*
ERROR at line 1:
ORA-02292: integrity constraint (SEC.FK_T_CHILD1) violated - child record found

sec@ora10g> select * from T_CHILD1;

 CHILD1_ID  PARENT_ID
---------- ----------
         1          1

在此类型下,不允许删除。

4.尝试对具有delete cascade类型外键参照的主表记录进行删除
sec@ora10g> delete from T_PARENT where parent_id = 2;

1 row deleted.

sec@ora10g> select * from T_CHILD2;

no rows selected

成功,级联删除成功。

5.尝试对具有delete set null类型外键参照的主表记录进行删除
sec@ora10g> delete from T_PARENT where parent_id = 3;

1 row deleted.

sec@ora10g> select * from T_CHILD3;

 CHILD2_ID  PARENT_ID
---------- ----------
         3

主表记录可以完成删除,子表中对应的内容被设置为NULL。

6.小结
以上就是在Oracle数据库,当主表信息删除后对应的子表中记录的三种不同的处理方式,针对具体的应用场合请选择合适类型。

Good luck.

secooler
10.03.21

-- The End --

相关文章
|
11月前
|
Oracle 关系型数据库 数据库
Oracle 不使用DBCA在Oracle 11中删除数据库
Oracle 不使用DBCA在Oracle 11中删除数据库
53 0
|
SQL Oracle 关系型数据库
Oracle rman备份保留策略,归档删除策略及delete命令的使用
oracle rman备份保留策略、归档策略的使用及对delete命令的影响
1523 0
|
Oracle 关系型数据库 数据安全/隐私保护
oracle学习25-手工删除oracle归档日志后操作步骤 和修改用户默认解锁时间
oracle学习25-手工删除oracle归档日志后操作步骤 和修改用户默认解锁时间
124 0
|
Oracle 关系型数据库
oracle学习47-oracle删除非空表空间
oracle学习47-oracle删除非空表空间
90 0
|
Oracle 关系型数据库 数据库
Oracle 使用脚本建库,删库及删除数据库软件
Oracle 使用脚本建库,删库及删除数据库软件
387 0
Oracle 使用脚本建库,删库及删除数据库软件
|
SQL Oracle 关系型数据库
Oracle删除重复数据只留一条
查询及删除重复记录的SQL语句
|
Oracle 关系型数据库 数据库
oracle 数据库问题:“ORA-01922: 必须指定 CASCADE 以删除...“,原因及解决办法
oracle 数据库问题:“ORA-01922: 必须指定 CASCADE 以删除...“,原因及解决办法
490 0
oracle 数据库问题:“ORA-01922: 必须指定 CASCADE 以删除...“,原因及解决办法
|
Oracle 关系型数据库 Linux
Oracle RMAN删除归档日志脚本
Oracle 开启归档模式后,会一直不停的产生归档日志,如果不定时删除,迟早会撑爆磁盘空间,所以就需要布置定时删除归档日志的脚本!
|
SQL Oracle 关系型数据库
Oracle/Mysql迁移到Postgresql事务回滚行为差异(开发避坑系列)
Mysql或Oracle迁移到Postgresql系产品后,经常会发生事务回滚导致的问题,具体问题一般都是类似于: **为什么我没rollback,我的事务就自己回滚了?** 下面我举一个简单的例子,说明下PG和其他两款DB在事务回滚行为上的差异 ## Oracle事务内报错后的行为 (完整代码贴在文章最后) ```java Class.fo
911 0
|
Oracle 关系型数据库 索引
删除Oracle用户及表空间
删除Oracle用户及表空间--转载自 https://blog.csdn.net/sunny05296/article/details/81126548--以sysdba用户登录,查找需要删除的用户conn / as sysdba --查找用户select * from dba_users;se...
2839 0

推荐镜像

更多