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

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

  • 相关阅读:
    允许debian wheezy支持IOS7+的iphone.
    openSUSE 国内镜像摘要
    策略模式总结
    顺序串
    WindowState注意事项
    NLP | 自然语言处理
    Using Autorelease Pool Blocks
    NSAutoreleasePool & thread
    oc语言特性
    oc语言基础整理
  • 原文地址:https://www.cnblogs.com/lovesong/p/3258478.html
Copyright © 2011-2022 走看看