如何在级联上删除自引用关系?
How to delete on cascade a self reference relationship?
我有一个具有自动引用关系的 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 行:
ID表A:1
IDTableARoot: 1
第 2 行:
ID表A:2
IDTableARoot: 1
当我尝试删除第 1 行时:
delete from TableA where IDTableA = 1;
只删除ID = 1的行,而不删除ID = 2的行,但应该删除,因为在触发器的第一条语句中我说我必须删除带有IDTableARoot = IDTableA 其中 IDTableA 是我要删除的行的 ID。
那么,如何在级联中删除属于自身关系的行?
非常感谢。
您正在尝试在 DELETE 触发器中执行另一个 DELETE,这是不允许的,因为这可能会进入无限循环。
您可能想要更改您对 INSTEAD OF DELETE
触发器的使用(参见此 link)并将您的触发器主体代码更改为如下内容
UPDATED:解决@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
希望对您有所帮助
我有一个具有自动引用关系的 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 行: ID表A:1 IDTableARoot: 1
第 2 行: ID表A:2 IDTableARoot: 1
当我尝试删除第 1 行时:
delete from TableA where IDTableA = 1;
只删除ID = 1的行,而不删除ID = 2的行,但应该删除,因为在触发器的第一条语句中我说我必须删除带有IDTableARoot = IDTableA 其中 IDTableA 是我要删除的行的 ID。
那么,如何在级联中删除属于自身关系的行?
非常感谢。
您正在尝试在 DELETE 触发器中执行另一个 DELETE,这是不允许的,因为这可能会进入无限循环。
您可能想要更改您对 INSTEAD OF DELETE
触发器的使用(参见此 link)并将您的触发器主体代码更改为如下内容
UPDATED:解决@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
希望对您有所帮助