• 技术文章 >数据库 >navicat

    navicat怎么建立外键

    angryTomangryTom2019-08-08 11:59:59原创4595

      数据库外键表示了两个关系之间的相关联系。以另一个关系的外键作主关键字的表被称为主表,具有此外键的表被称为主表的从表。下面我们就为大家介绍一下navicat如何创建外键。

    推荐教程:MySQL入门视频教程

    1、打开navicat选择要操作的数据库表,右键选择设计表。

    navicat62.png

    2、点击外键选项就可以开始设置外键了。

    navicat63.png

    一共有七列。简单介绍一下这几列的意思:

      “名”: 可以不填,你一会保存成功系统会自动生成。

      “栏位”:就是你要把哪个键设置为外键。

      “参考数据库”: 外键关联的数据库。

      “参考表”: 关联的表

      “参考栏位”:关联的的字段,

      “删除时":就是删除的时候选择的动作。

      “ 更新时”:就是更新的时候选择的动作。

    扩展资料:外键的作用

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

      如果不使用外键,表2的学号字段插了一个值(比如20140999999),但是这个值在表1中并没有,这个时候,数据库允许插入,并不会对插入的数据做关系检查。然而在设置外键的情况下,你插入表2学号字段的值必须要求在表1的学号字段能找到。 同时,如果你要删除表1的某个学号字段,必须保证表2中没有引用该字段值的列,否则就没法删除。这就是所谓的保持数据的一致性和完整性。如右图,如果表2还引用表1的某个学号,你却把表1中的这个学号删了,表2就不知道这个学号对应的学生是哪个学生。

      数据库中的表必须符合规范,才能杜绝数据冗余、插入异常、删除异常等现象。规范的过程是分解表的过程。经过分解,伺一事物的代表属性出现在不同的表中。显然,它们应该保持一致。例如,某学生的代表数据是学号012,在学生表里是012,在成绩表里也应该是012。这种一致性由外键实现。外键的功能是:它的值一定是另一个表的主键值。学号在学生表里是主键,在成绩表里是外键。成绩表里的学号一定要是学生表里的学号。于是,学生表里的学号和成绩表里的学号就一致了。可以直观地理解,外键的功能是实现同一事物在不同表中的标志一致性。2功能的实现由外键联系的两个表,在单独操作时,外键功能由两种方法实现 [4] :

    阻止执行

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

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

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

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

    级联执行

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

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

      ●两种实现方法,通过下面方式选择:

      ●界面:设级联更新、级联删除两个选择方框,选取则级联执行、不选取则阻止执行;

      ●命令:设E)kSCM)E、RESTRICT两个可选项,CASCADE为级联执行、RESTRICT为阻止执行。

    以上就是navicat怎么建立外键的详细内容,更多请关注php中文网其它相关文章!

    声明:本文原创发布php中文网,转载请注明出处,感谢您的尊重!如有疑问,请联系admin@php.cn处理
    专题推荐:navicat 外键
    上一篇:navicat怎么看触发器 下一篇:navicat怎么新建查询
    线上培训班

    相关文章推荐

    • navicat是哪个公司开发的• navicat怎么导入表格数据• navicat premium中如何清空表• navicat 1366错误

    全部评论我要评论

  • 取消发布评论发送
  • 1/1

    PHP中文网