如何在级联上删除自引用关系?

时间:2016-01-16 16:26:01

标签: sql-server triggers cascading-deletes self-referencing-table

我有一个具有自动引用关系的表,如下所示:

TableA(IDTableA,IDTableARoot,...)

我有这个而不是删除触发器删除:

Delete from TableA where IDTableARoot IN(select deleted.IDTableA from deleted)
    Delete from TableA where IDTableA IN(select deleted.IDTableA from deleted)

我想我有这两行:

第1行: IDTableA:1 IDTableARoot:1

第2行: IDTableA:2 IDTableARoot:1

当我尝试删除第1行时:

delete from TableA where IDTableA = 1;

只删除ID = 1的行,但不删除ID = 2的行,但是在触发器的第一个语句中删除了被删除我说我必须删除IDTableARoot =的行IDTableA,其中IDTableA是我要删除的行的ID。

那么,我怎样才能删除属于自我关系的级联行?

非常感谢你。

1 个答案:

答案 0 :(得分:2)

您正在尝试在DELETE触发器中执行另一个DELETE,这是不允许的,因为它可以进入无限循环。

您可能希望更改使用INSTEAD OF DELETE触发器(请参阅此link)并将触发器正文代码更改为以下内容

更新:解决@TT指出的错误。

CREATE TABLE #CascadeDeleteRows (IDTableA int, IDTableARoot int)

INSERT 
  INTO #CascadeDeleteRows 
SELECT b.IDTable
     , b.IDTableARoot 
  FROM TableA
 WHERE b.IDTableA IN (SELECT deleted.IDTableARoot from deleted)

DELETE 
  FROM TableA 
 WHERE IDTableA IN (SELECT #CascadeDeleteRows.IDTableA FROM #CascadeDeleteRows)

DROP TABLE #CascadeDeleteRows

希望这有帮助