Oracle on delete cascade/on delete set null/on delete no action 区别

本文详细介绍了在外键约束中定义的三种引用行为:级联删除(on delete cascade),设置为空(on delete set null)以及不采取任何行动(on delete no action)。这些选项决定了当主表中的记录被删除时,子表中的相关记录将如何处理。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

引用行为(当主表中一条记录被删除时,确定如何处理子表中的外部码字段):

on delete cascade : 删除子表中所有的相关记录,适用于需要级联删除的场景。
on delete set null : 将所有相关记录的外部码字段值设置为NULL,适用于希望保留子表记录但移除关联关系的场景。
on delete no action: 当试图删除父表中的记录时,如果子表中存在引用,则拒绝删除操作。适用于严格维护数据完整性,不允许孤立记录出现。

使用:用于外键约束。

alter table emp
add constraint fk_emp_dept foreign key(dept) references dept(deptno)

on delete cascade;

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值