请问一下数据库中的外键的作用是什么,它是用来干嘛的?一直不是很理解,还请帮忙回答一下,谢谢。
3条回答 默认 最新
关注
外键的作用:
保持数据一致性,完整性,主要目的是控制存储在外键表中的数据。 使两张表形成关联,外键只能引用外表中的列的值或使用空值。
阻止执行:
1、从表插入新行,其外键值不是主表的主键值便阻止插入;
2、从表修改外键值,新值不是主表的主键值便阻止修改;
3、主表删除行,其主键值在从表里存在便阻止删除(要想删除,必须先删除从表的相关行);
4、主表修改主键值,旧值在从表里存在便阻止修改(要想修改,必须先删除从表的相关行)。
级联执行:
1、主表删除行,连带从表的相关行一起删除;
2、主表修改主键值,连带从表相关行的外键值一起修改。两种方法提供给用户选择。无论选取哪种方法,从表里都不会有多余行。从另一个角度理解,用拒绝同一事物在从表中的标志与主表不一致来实现与主表中的标志一致。
注:现在工作中数据库表的设计都不用外键,因为总的来说外键是表之间的约束,当数据量多的时候弊大于利
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报