Oracle外键级联删除和级联更新

本文详细介绍了Oracle中外键在级联删除时的三种行为:NO ACTION、SET NULL和CASCADE,并通过学生-班级的例子进行了示例说明。同时,文章探讨了Oracle不直接支持的级联更新,提出了利用延迟约束和触发器实现类似效果的方法。

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


1 级联删除


Oracle在外键的删除上有NO ACTION(类似RESTRICT)、CASCADE和SET NULL三种行为。

下面以学生-班级为例说明不同情况下的外键删除,学生属于班级,班级的主键是学生的外键。

-- 班级表
CRATE TABLE TB_CLASS
(
  ID    NUMBER NOT NULL, --班级主键
  NAME  VARCHAR2(50), --班级名称
  CONSTRAINT PK_TB_CLASS PRIMARY KEY (ID)
);

-- 学生表
CREATE TABLE TB_STUDENT
(
  ID        NUMBER NOT NULL,   --学生主键
  NAME      VARCHAR2(50),      --学生姓名
  CLASS_ID  NUMBER,            --学生所属班级,外键
  
  --主键约束
  CONSTRAINT PK_TB_STUDENT PRIMARY KEY (ID),
  
  --外键约束
  --设置级联删除为NO ACTION
  CONSTRAINT FK_TB_STUDENT_CLASS_ID FOREIGN KEY (CLASS_ID) REFERENCES TB_CLASS (ID)
);

-- 添加班级数据
INSERT INTO TB_CLASS (ID, NAME) VALUES (1, '一班');
INSERT INTO TB_CLASS (ID, NAME) VALUES (2, '二班');
INSERT INTO TB_CLASS (ID, NAME) VALUES (3, '三班');

-- 添加学生数据
INSERT INTO TB_STUDENT (ID, NAME, CLASS_ID) VALUES (1, '小明', 1);
INSERT INTO TB_STUDENT (ID, NAME,
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值