zoukankan      html  css  js  c++  java
  • SQLServer表内自关联级联删除

    今天处理SQLServer级联删除遇到了很蛋疼的事。

    SQLServer 不支持表内自关联级联删除,而MySql和Oracle却支持。

    貌似原因是SQLServer 会产生循环级联,就不给这样弄。所以很明确说:SQLServer 是不支持表内自关联级联删除

    那怎么办呢:只能用触发器呗

    IF EXISTS (SELECT NAME FROM SYSOBJECTS
          WHERE NAME = 'tg_SysDelete' AND TYPE = 'TR')
       DROP TRIGGER tg_SysDelete
    GO
    
    CREATE TRIGGER tg_SysDelete
    ON SysSiteMap
    FOR DELETE 
    AS 
    IF (SELECT COUNT(*) FROM DELETED) > 0
       DELETE FROM SysSiteMap WHERE ParentId  IN (SELECT Id FROM DELETED)
    GO  

    PS:SQLServer为每个触发器都创建了两个专用表:Inserted表和Deleted表。这两个表。

    单单是这样是级联删除不了的,需要开启数据库的递归触发器功能

    开启办法:手动设置:数据库上点右键->属性->选项 设置 递归触发器已启用 为 true

                 sql语句启动:ALTER DATABASE 数据库名称 SET RECURSIVE_TRIGGERS ON

     貌似SQLServer还有以下问题:

    一个表内在有多个列同时关联于另一个表时,不支持多个级联删除 ,循环级联删除限制

  • 相关阅读:
    原始字符串
    .Net Core 常见错误解决记录
    P1010 幂次方 P1022 计算器的改良
    P1036 选数
    广度优先遍历
    P4327 彼得潘框架
    链表
    标准库与标准模板库
    信息学竞赛打表犯规吗?
    对拍程序
  • 原文地址:https://www.cnblogs.com/lovesong/p/3258478.html
Copyright © 2011-2022 走看看