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

前端之家收集整理的这篇文章主要介绍了sql – 如何CASCADE从子表删除到父表?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我准备了 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锁定,以防止出现任何争用情况.

猜你在找的MsSQL相关文章