当前位置: 首页 > 图文教程 > 数据库 > MSSQL > 对Sql Server中的表添加级联更新和级联删除

MSSQL
浅析SQL Server与Oracle、DB2的比较
SQL Artisan数据库访问组件功能概述
50种方法巧妙优化你的SQL Server数据库
SQL Server 2005数据库管理10个特点
拷贝的SQL Server 7的恢复方法
SQL Server 2000启动1069错误解决方法
SQL Server 2005—数据库管理10个特点
SQL概述及在网络安全中的应用(下)
深入浅出SQL教程之SELECT语句的自连接
SQL Server查询设计:避免10个错误
SQL概述及在网络安全中的应用(上)
某外企SQL Server面试题
解决MSSQL占用过多内存的简单方法介绍
安装SQL Server 2005实例环境图解
步骤指南:如何合并SQL Server
SQL Server查询处理器机制与结构(下)
避免在 SQL Server 中盲目地追求一句处理
Sql Sever数据库自动备份
SQL Server查询处理器机制与结构(上)
精华推荐:加速SQL查询的特征函数法

MSSQL 中的 对Sql Server中的表添加级联更新和级联删除


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-08-14   浏览: 630 ::
收藏到网摘: n/a

以前用Sql Server只会对图形界面进行操作,现在发现自己的Sql语言功底是越来越差了,例如如何为两个表添加关联,让他们级联更新和级联删除。
到晚上查了一下,发现可以用两种办法

触发器方式:
create trigger trg_A
on A
for update,delete
as
begin
    if exists(select 1 from inserted)
        update B set Name=(select Name from inserted) where Name=(select Name from deleted)
    else
        delete B where Name=(select Name from deleted)
end
go

级联更新和级联删除方式:
ALTER TABLE [dbo].[T_USERGROUP] ADD
        CONSTRAINT [FK_T_USERGROUP_T_ACCTTEMPLATE] FOREIGN KEY
        (
                [ATNAME]
        ) REFERENCES [dbo].[T_ACCTTEMPLATE] (
                [ATNAME]
        ) ON UPDATE CASCADE ON DELETE CASCADE