1

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

表A(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。

那么,如何删除属于自我关系的级联行?

非常感谢。

4

1 回答 1

2

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

您可能想要更改使用INSTEAD OF DELETE触发器(请参阅此链接)并将触发器主体代码更改为如下所示

更新:解决@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

希望这可以帮助

于 2016-01-16T16:49:48.463 回答