sql 外键 删除

 1。企业管理器  
  打开你建有外键的表--右击表--设计表--在上方点开’管理约束‘--将级连删除和级连更新的沟打上就可以了  
  2。查询分析器  
  alter   table   sc  
  add  
  constraint   forei     foreign   key(sno)  
    REFERENCES   student(sno)  
  ON   DELETE     CASCADE                          
  ON   UPDATE     CASCADE  

 

ON   DELETE   {CASCADE   |   NO   ACTION}  
   
  指定当表中被更改的行具有引用关系,并且该行所引用的行从父表中删除时,要对被更改行采取的操作。默认设置为   NO   ACTION。    
   
  如果指定   CASCADE,则从父表中删除被引用行时,也将从引用表中删除引用行。如果指定   NO   ACTION,SQL   Server   将产生一个错误并回滚父表中的行删除操作。  
   
  如果表中已存在   ON   DELETE   的   INSTEAD   OF   触发器,那么就不能定义   ON   DELETE   的CASCADE   操作。  
   
  例如,在   Northwind   数据库中,Orders   表和   Customers   表之间有引用关系。Orders.CustomerID   外键引用   Customers.CustomerID   主键。  
   
  如果对   Customers   表的某行执行   DELETE   语句,并且为   Orders.CustomerID   指定   ON   DELETE   CASCADE   操作,则   SQL   Server   将在   Orders   表中检查是否有与被删除的行相关的一行或多行。如果存在相关行,那么   Orders   表中的相关行将随   Customers   表中的被引用行一同删除。  
   
  反之,如果指定   NO   ACTION,若在   Orders   表中至少有一行引用   Customers   表中要删除的行,则   SQL   Server   将产生一个错误并回滚   Customers   表中的删除操作。  
   
  ON   UPDATE   {CASCADE   |   NO   ACTION}  
   
  指定当表中被更改的行具有引用关系,并且该行所引用的行在父表中更新时,要对被更改行采取的操作。默认设置为   NO   ACTION。    
   
  如果指定   CASCADE,则在父表中更新被引用行时,也将在引用表中更新引用行。如果指定   NO   ACTION,SQL   Server   将产生一个错误并回滚父表中的行更新操作。  
   
  如果表中已存在   ON   DELETE   的   INSTEAD   OF   触发器,那么就不能定义   ON   DELETE   的CASCADE   操作。  
   
  例如,在   Northwind   数据库中,Orders   表和   Customers   表之间有引用关系。Orders.CustomerID   外键引用   Customers.CustomerID   主键。  
   
  如果对   Customers   表的某行执行   UPDATE   语句,并且为   Orders.CustomerID   指定   ON   UPDATE   CASCADE   操作,则   SQL   Server   将在   Orders   表中检查是否有与被更新行相关的一行或多行。如果存在相关行,那么   Orders   表中的相关行将随   Customers   表中的被引用行一同更新。  
   
  反之,如果指定了   NO   ACTION,若在   Orders   表中至少存在一行引用   Customers   表中要更新的行,那么   SQL   Server   将引发一个错误并回滚   Customers   表中的更新操作。  

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值