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

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

  • 相关阅读:
    精益产品探索
    vue 之 pdf预览
    arcgis js 之 渔网工具(调用地图服务)
    arcgis js之卷帘工具
    arcgis js之调用wms服务
    vue-cli3 本地数据模拟后台接口
    cmd设置电脑自动关机
    Arcgis js之web墨卡托(3857)转经纬度坐标(4326)
    arcgis js之地图分屏同步
    arcgis之gp服务发布
  • 原文地址:https://www.cnblogs.com/lovesong/p/3258478.html
Copyright © 2011-2022 走看看