• 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还有以下问题:

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

  • 相关阅读:
    UnityShaderVariant的一些探究心得
    NGUI在使用AssetBubble 出现材质丢失错误的情况
    [转] unity调试lua工具和方法
    各种文件的mime类型
    Javascript 随机数
    jQuery文字上下滚动
    Asp.Net Color转换
    Asp.Net 清除Html标签
    jQuery Ajax实例
    Asp.Net Cookie用法
  • 原文地址:https://www.cnblogs.com/lovesong/p/3258478.html
Copyright © 2020-2023  润新知