数据库中的外键作用是什么

请问一下数据库中的外键的作用是什么,它是用来干嘛的?一直不是很理解,还请帮忙回答一下,谢谢。

外键的作用:

保持数据一致性,完整性,主要目的是控制存储在外键表中的数据。 使两张表形成关联,外键只能引用外表中的列的值或使用空值。

阻止执行:

1、从表插入新行,其外键值不是主表的主键值便阻止插入;

2、从表修改外键值,新值不是主表的主键值便阻止修改;

3、主表删除行,其主键值在从表里存在便阻止删除(要想删除,必须先删除从表的相关行);

4、主表修改主键值,旧值在从表里存在便阻止修改(要想修改,必须先删除从表的相关行)。

级联执行:

1、主表删除行,连带从表的相关行一起删除;

2、主表修改主键值,连带从表相关行的外键值一起修改。两种方法提供给用户选择。无论选取哪种方法,从表里都不会有多余行。从另一个角度理解,用拒绝同一事物在从表中的标志与主表不一致来实现与主表中的标志一致。

注:现在工作中数据库表的设计都不用外键,因为总的来说外键是表之间的约束,当数据量多的时候弊大于利

外键就是你这个表中的某个字段值,必须是另一个表中的关键字。
对于这种情况,你可以把这个字段设置为外键。这样数据库就会进行相应的检查。

就是关联另外一张表中对应数据的,比如student表里面有个字段是学号,然后competition表里面也有一个字段学号,学号就是competition的外键 因为我们不能把student里面所有的信息都加到competition表里面,不然会让它冗余,所以我们用了一个外键,便于我们在student表里面查找这个学号对应的学生的信息。