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锁定,以防止出现任何争用情况. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |