数据库_级联更新/级联删除_ON UPDATE CASCADE/ON DELETE CASCADE

来源:互联网 发布:js 树形菜单递归函数 编辑:程序博客网 时间:2024/05/12 01:26

ON UPDATE CASCADE / ON DELETE CASCADE

级联更新与级联删除需要设置在从表上,


on update cascade 级联更新on delete cascade 级联删除意思是 当你更新或删除主键表时,那么外键表也会跟随一起更新或删除
CREATE TABLE Countries(CountryId INT PRIMARY KEY) 
INSERT INTO Countries (CountryId) VALUES (1) 
INSERT INTO Countries (CountryId) VALUES (2) 
INSERT INTO Countries (CountryId) VALUES (3) 
GO 
CREATE TABLE Cities( CityId INT PRIMARY KEY  ,CountryId INT REFERENCES Countries ON DELETE CASCADE); 
INSERT INTO Cities VALUES(1,1) 
INSERT INTO Cities VALUES(2,1) 
INSERT INTO Cities VALUES(3,2) 
GO 
CREATE TABLE Buyers(CustomerId INT PRIMARY KEY ,CityId INT REFERENCES Cities ON DELETE CASCADE); 
INSERT INTO Buyers  VALUES(1,1), 
INSERT INTO Buyers  VALUES(2,1) 
INSERT INTO Buyers  VALUES(3,2) 
GO 

命令: 
DELETE FROM Countries WHERE CountryId = 1 
结果: 
Countries: 
CountryId 


Cities: 
CityId CountryId 
3 2 
Buyers: 
CustomerId CityId 

ON UPDATE CASCADE的用法和ON DELETE CASCADE差不多 

0 0
原创粉丝点击