博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
SQL 添加外键约束
阅读量:4158 次
发布时间:2019-05-26

本文共 1328 字,大约阅读时间需要 4 分钟。

语法如下:
ALTER TABLE pc ADD CONSTRAINT fk_cpu_model FOREIGN KEY (cpumodel) REFERENCES parts(model);

 

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 表中的更新操作。

 

转载地址:http://jryxi.baihongyu.com/

你可能感兴趣的文章
谷歌 Flutter 2.0 新特性概览
查看>>
联想E440设置U盘启动的方法
查看>>
ubuntu设置ip和dns
查看>>
jboss 上传文件路径解决
查看>>
java时间操作函数汇总
查看>>
Js在两个 Frame 之间传值
查看>>
webservice开发中的nor any of its super class is known to this context错误解决
查看>>
drawable(hdpi,ldpi,mdpi) 的区别
查看>>
java新手走android捷径不足一年月薪3w!
查看>>
Android Handler总结
查看>>
AdapterView.OnItemClickListener
查看>>
BigDecmal 舍位模式
查看>>
Android开发指南-用户界面-事件处理
查看>>
getSystemService
查看>>
如何制作能记录学习进度的SCORM标准课件
查看>>
Eclipse集成Android NDK详解
查看>>
正确使用Android性能分析工具——TraceView
查看>>
Android Studio 常用设置
查看>>
android调试工具DDMS的使用详解
查看>>
AndroidStudio开发环境搭建
查看>>