数据库点滴之SQL级联删除

数据库
删除包含主键值的行的操作,该值由其它表的现有行中的外键列引用。在级联删除中,还删除其外键值引用删除的主键值的所有行。

功能:在删除主表时,自动删除副表(外键约束)相应内容

删除包含主键值的行的操作,该值由其它表的现有行中的外键列引用。在级联删除中,还删除其外键值引用删除的主键值的所有行。

如:

  1. create database temp 
  2. go 
  3. use temp 
  4. go 
  5.  
  6. create table UserInfo 
  7. UserId int identity(1,1) primary key , 
  8. UserName varchar(20),  --用户名 
  9. password varchar(20) not null --密码 
  10.  
  11. create table UserDetails 
  12. id int identity(1,1) primary key
  13. name varchar(50) not null--真实姓名 
  14. userId int
  15. foreign key (userId) references UserInfo(UserId) on delete cascade 
  16.  
  17. insert UserInfo values ('ly','jeff'
  18. insert UserInfo values('wzq','wzqwzq'
  19. insert UserInfo values('lg','lglg'
  20.   
  21. insert UserDetails values('李四',1) 
  22. insert UserDetails values('王五',2) 
  23. insert UserDetails values('刘六',3) 

SQL Server支持级联更新和删除

Oracle只支持级联删除

  1. alter table 表名 
  2. add constraint 外键名 
  3. foreign key(字段名) references 主表名(字段名) 
  4. on delete cascade 

语法:

  1. Foreign Key 
  2. (column[,...n]) 
  3. references referenced_table_name[(ref_column[,...n])] 
  4. [on delete cascade
  5. [on update cascade

注释:

  • column:列名
  • referenced_table_name:外键参考的主键表名称
  • ref_name:外键要参考的表的主键列
  • on delete:删除级联
  • on update:更新级联

原文链接:http://www.cnblogs.com/jyshis/archive/2011/09/06/2140257.html

【编辑推荐】

  1. 养成一个SQL好习惯带来一笔大财富
  2. 告诉你,如何成就DBA职业生涯
  3. 经验来源于实践,今天你总结了吗?
  4. 客户的一次疏忽,DBA的一次噩梦
  5. 数据库点滴之精妙SQL语句
责任编辑:艾婧 来源: 我的点点滴滴的博客
相关推荐

2011-09-09 10:10:13

SQL数据库点滴

2011-05-06 16:36:48

SQL备份还原

2011-10-09 16:40:50

T-SQL

2011-06-23 14:00:51

SQL点滴

2011-04-21 10:06:40

SQL筛选

2010-09-02 09:45:07

SQL删除

2010-11-10 11:47:35

SQL Server级

2010-09-03 11:00:47

SQL删除

2011-03-28 14:16:31

SQL Server 数据库

2011-03-15 09:55:07

SQL Server2数据库崩溃还原数据库

2011-05-11 09:49:32

线程等待SQL Server

2010-11-10 11:51:04

SQL SERVER级

2011-03-15 09:52:40

SQL Server2数据库恢复系统

2010-07-15 17:28:50

SQL Server

2014-07-18 09:33:53

数据库数据库优化

2010-09-02 11:24:45

SQL删除

2010-07-16 10:29:02

SQL Server

2010-09-01 16:40:00

SQL删除触发器

2010-06-30 14:24:08

SQL Server数

2021-05-17 06:57:34

SQLServer数据库
点赞
收藏

51CTO技术栈公众号