【问题标题】:How to delete on cascade a self reference relationship?如何在级联上删除自引用关系?
【发布时间】:2016-01-16 16:26:00
【问题描述】:

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

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。

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

非常感谢。

【问题讨论】:

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


    【解决方案1】:

    您正在尝试在 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
    

    希望对你有帮助

    【讨论】:

    • @TT,感谢您指出,我已经更新了答案.. 希望这有效
    猜你喜欢
    • 1970-01-01
    • 2017-07-02
    • 2017-11-17
    • 1970-01-01
    • 2021-09-24
    • 1970-01-01
    • 2016-04-11
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多