加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MsSql教程 > 正文

sql – 如何CASCADE从子表删除到父表?

发布时间:2020-12-12 06:57:52 所属栏目:MsSql教程 来源:网络整理
导读:我准备了 a fiddle which demonstrates the problem. CREATE TABLE parent ( parent_id integer primary key);CREATE TABLE child ( child_name TEXT primary key,parent_id integer REFERENCES parent (parent_id) ON DELETE CASCADE);INSERT INTO parent VA
我准备了 a fiddle which demonstrates the problem.
CREATE TABLE parent (
   parent_id integer primary key
);

CREATE TABLE child (
   child_name TEXT primary key,parent_id integer REFERENCES parent (parent_id) ON DELETE CASCADE
);

INSERT INTO parent VALUES (1);
INSERT INTO child VALUES ('michael',1),('vanessa',1);

我想要一种删除子记录时删除CASCADE到父记录的方法.
例如:

DELETE FROM child WHERE child_name='michael';

这应该级联到父表并删除记录.

解决方法

外键仅在另一个方向上工作:级联从父级删除到子级,因此当删除父级(引用的)记录时,也会删除任何子级(引用)记录.

如果它是1:1的关系,你可以创建一个双向外键关系,其中一边是可以推迟的,并且两边都是级联的.

否则,您将需要子表上的ON DELETE … FOR EACH ROW触发器,如果??没有剩余子项,则删除父行.它可能容易出现并发INSERT的竞争条件;你需要SELECT … FOR UPDATE父记录,然后检查其他子记录.对插入的外键检查会对引用的(父)记录执行FOR SHARE锁定,以防止出现任何争用情况.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读