数据库中的外码约束指用于在两个表之间建立关系,需要指定引用主表的哪一列。对于存在外码约束的表,如果进行删除非空的外码,可能会出现错误。如果在外码约束的列中输入非 NULL 值,则此值必须在被引用的列中存在,否则将返回违反外码约束的错误信息。
扩展资料:
外码约束仅能引用位于同一服务器上的同一数据库中的表。数据库间的引用完整性必须通过触发器实现。一个表最多可包含 253 个外码约束。对于临时表不强制 外码约束。
有外码约束可以引用同一表中的其它列(自引用)。列级外码约束的 REFERENCES 子句仅能列出一个引用列,且该列必须与定义约束的列具有相同的数据类型。
表级外码约束的 REFERENCES 子句中引用列的数目必须与约束列列表中的列数相同。每个引用列的数据类型也必须与列表中相应列的数据类型相同。
数据库中的外部代码约束用于通过指定引用主表的哪一百列来建立两个表之间的关系。对于带有outcode约束的表,如果删除非空的outcode,可能会发生错误。
如果在外部代码约束的列中输入了非空值,则该值必须存在于引用的列中,否则将返回违反外部代码约束的错误消息。
扩展资料:
外部通道约束只能引用同一服务器上相同数据库中的表。数据库之间的引用完整性必须通过触发器来实现。一个表最多可以包含253个外部代码约束。对于临时表不强制执行外部代码约束。
有些代码约束可以引用同一表中的其他列(自引用)。列级外部代码约束的REFERENCES子句只能列出一个引用列,而且该列必须具有与定义约束的列相同的数据类属类型。
表级外部代码约束的REFERENCES子句中的引用列数必须与约束列列表中的列数相同。每个引用列的数据类型也必须与列表中相应列的数据类型相同。
级联删除:当删除A里的数据后,B表内含该ID的行会自动由数据库删除。比如把某个学生ID删除了,那么他的分数之类的信息也要删除,留着也是垃圾数据。
受限删除:当要删除A内的数据,而B中又存在相关id的行,那么将不会执行删除,必须先把B内的这些行删除掉,再删除a里的数据。
更加详细的你可以去看MSsql联机丛书关于级联删除等的介绍。以下来自sql联机丛书:
ON DELETE NO ACTION
指定如果试图删除某行,而该行含有由其它表的现有行中的外键所引用的键,则产生错误并回滚 DELETE。
ON UPDATE NO ACTION
指定如果试图更新某行中的键值,而该行含有由其它表的现有行中的外键所引用的键,则产生错误并回滚 UPDATE。
CASCADE 允许在表间级联键值的删除或更新操作,这些表的外键关系可追溯到执行修改的表。不能为任何具有 timestamp 列的外键和主键指定 CASCADE。
ON DELETE CASCADE
指定如果试图删除某行,而该行含有由其它表的现有行中的外键所引用的键,则也将删除所有包含那些外键的行。如果在目标表上也定义了级联引用操作,则对从那些表中删除的行同样采取指定的级联操作。
ON UPDATE CASCADE
指定如果试图更新某行中的键值,而该行的键值由其它表的现有行中的外键所引用,则所有外键值也将更新成为该键指定的新值。如果在目标表上也定义了级联引用操作,则对在那些表中更新的键值同样采取指定的级联操作。
上面就是外码约束的概念,希望你能明白它的作用。