删除引用已删除行的行和其他行 [英] Delete rows and other rows with a reference to the deleted row

查看:21
本文介绍了删除引用已删除行的行和其他行的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我使用的是PostgreSQL,我有一个表family如下所示:

+----+-------+-----------+
| id | name  | parent_id |
+----+-------+-----------+
|  1 | adam  |         0 |
|  2 | eva   |         0 |
|  3 | peter |         2 |
|  4 | pan   |         3 |
+----+-------+-----------+

现在,当我删除人员时,我也希望删除孩子。因此,例如,删除WHERE name='peter'将从列表中删除'peter''pan'。 当我删除'eva'时,'peter''pan'被删除。

现在我考虑删除初始行,并从删除的行中获取id。然后我会继续删除,直到现在id被返回。请注意,一个人只有一个父母,但可以有几个孩子。

SQL中有没有一种巧妙的方法来解决这个问题?如果没有,我如何取回所有已删除行的ID?

推荐答案

最佳解决方案是创建使用on delete cascade定义的适当外键。它需要存储NULL值,而不是在parent_id列中存储神奇的"零":

create table family 
(
  id int primary key, 
  name varchar(5), 
  parent_id int, 
  foreign key (parent_id) references family on delete cascade
);

然后您所需要的就是:

delete from family
where name = 'peter';

Online example


如果您想要转换现有的表和数据,可以这样做:

--- change all zeroes to NULL
update family 
  set parent_id = null
where parent_id = 0;

-- add a primary key in order to be able to create a foreign key
alter table family add primary key (id);

-- add the foreign key 
alter table family 
  add foreign key (parent_id) references family (id)
  on delete cascade;

这篇关于删除引用已删除行的行和其他行的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆