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

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

转载:http://www.cnblogs.com/lovesong/p/3258478.html

时间: 2024-12-30 22:31:07

SQLServer表内自关联级联删除的相关文章

解析Oracle中多表级联删除的方法

创建数据库时为了防止其他人不小心删除操作错误, 所有的外键都没有加级联删除.哪知,不知什么时候自己入了一批错误的数据进去,入库使用的是软件自动的,一下点错给自己带来无尽麻烦啊,删除就不好办了   表间的关系比较复杂,数据量又比较多,一个个删绝对会出大问题.于是实验了几种解决的办法,现小结一下. 方法一:创建约束时设定级联删除(但一般由于各种原因或出于各种考虑在创建数据库时没有设定级联删除)SQL语句: 复制代码 代码如下: CREATE TABLE "U_WEN_BOOK"."

datagridview-C#如何将DataGridView1中选中的行删除(SQLserver表中的主键为“学号”)

问题描述 C#如何将DataGridView1中选中的行删除(SQLserver表中的主键为"学号") //删除按钮代码private void dele_Click(object sender EventArgs e) { string cnnstr = ""Data Source=.;Database=stutable;User id=sa;PWD=m123""; SqlConnection cnn = new SqlConnection(c

stu-hibernate 3张表,都是双向一对多,怎么级联删除??

问题描述 hibernate 3张表,都是双向一对多,怎么级联删除?? 三张表,一张grade,一张stu,一张score,配的都是双向一对多,怎么删除delete(grade),对应删除stu,score对应的内容???????????? hibernate 最多只能两张表级联双向一对多吗??? 现在能够级联增加,就是不能删除!!只有一句SQL语句,只删除了grade!!!!!!!!没有其他提示!!!配置都是正确的!!!

hibernate级联删除时无法删除,一对多双向关联,一是Consult 多是TbFiles

问题描述 hibernate级联删除时无法删除,一对多双向关联,一是Consult 多是TbFiles 一的配置: 多的配置: class="com.project.dto.Consult" fetch="select" cascade="all"> 执行代码: public void delConsult(String[] ids){ HibernateTemplate hTemplate=this.getHibernateTemplat

Oracle中多表级联删除的语句总结

最简单快速的删除 下面要讲到了涉及多表级联删除到数据量较大以及表间关系比较复杂时才有效率上的优势,简单的直接删除来的更快      如上例中,直接删除  代码如下 复制代码      DELETE FROM "FG123"."ORDERCOMBINE"      WHERE VIPForm ='1':      DELETE FROM "FG123"."ORDERCOMBINE"      WHERE FormerId ='1

[NHibernate]一对多关系(级联删除,级联添加)

目录 写在前面 文档与系列文章 一对多关系 一个例子 级联删除 级联保存 总结 写在前面 在前面的文章中,我们只使用了一个Customer类进行举例,而在客户.订单.产品中它们的关系,咱们并没有涉及,比如一个客户可以有一个或者多个订单,在数据库中变现为"主外键关系",有时也喜欢称为"父子关系".那么就让我们一起学习,在nhibernate中,是如何处理这种关系的吧? 文档与系列文章 [Nhibernate]体系结构 [NHibernate]ISessionFacto

hibernate 级联删除问题

问题描述 小女子大问题====hibernate级联删除问题====现有相册(Album)和照片2个表(Photo)我想在删除相册的同时删除相册里所有的照片两个表的实体和映射如下publicclassAlbumimplementsSerializable{privateintid;privateStringname;//名称privateStringdescription;//描述privateStringpwd;//密码privateAlbumStatealbumState;//状态多对一单向

递归-一个比较复杂的级联删除问题 ,求高手指点

问题描述 一个比较复杂的级联删除问题 ,求高手指点 是这样的,现在要做一个通用的删除方法.删除一个配置项和其关联配置项,逻辑很复杂.首先,数据库结构大概是这样的:有N个配置项,每个配置项有一张表,每个配置项通过一个中间表和其他配置项关联.有一对一,也有一对多的.所谓配置项一般都是一种设备,有序列号CI,ROWID来区分标识,每个设备有唯一的CI,但ROWID不唯一,ROWID是递增的,用HISTORY字段来区分是否在用.新增一个设备时是新生成一个CIROWID,HISTORY为1,表示在用.而更

讲解SQL与Oracle外键约束中的级联删除

最近软件系统中要删除一条记录,就要关联到同时删除好多张表,它们之间还存 在着约束关系.所以考虑到在创建表时加上约束关系,详细内容如下: SQL的外键约束可以实现级联删除与级联更新; ORACLE则只充许级联删除. SQL级联删除与级联更新使用格式: CREATE TABLE A001(ID INT PRIMARY KEY,NAME VARCHAR(20)) CREATE TABLE A002(ID INT REFERENCES A001(ID)ON DELETE CASCADE ON UPDAT