• 外键


    外键

    外键:foreign key,外面的键(键不在自己表中),如果一张表中有一个字段(非主键)指向另外一张表中的主键,那么该字段称之为外键.

    增加外键
    1.外键可以在创建表的时候或者创建表之后增加(但是要考虑数据的问题) 一张表可以有多个外键
    2.创建表的时候增加外键:在所有的表字段之后,使用foreign key(外键字段)references 外部表(主键字段)

     

    外键要求字段本身必须是一个索引(普通索引),如果字段本身没有索引,外键会先创建一个索引,然后才会创建外键本身

    在新增表之后增加外键:修改表结构
    alter table 表名 add [constraint 外键名字(自己命名)] foreign key(外键字段) references 父表(主键字段);

    修改外键&删除外键


    外键 不可修改:只能先删除后新增
    删除外键语法
    Alter table 表名 drop foreign key 外键名; --一张表中可以有多个外键,但是名字不能相同

    外键删除不能通过查看表结构体现,应该通过查看表创建语句查看

    外键作用
    外键默认的作用有两点:一个对父表,一个对子表(外键字段所在的表)

    对子表约束:子表数据进行写操作的时候,如果对应的外键字段在父表找不到对应的 匹配,那么操作失败.(约束子表数据操作)

    不能新增或者更新子表中的行 外键失败:c_id引用了my_class表中的ID:而4在my_class中不存在

    对父表约束:父表数据进行写操作(删和改:都必须涉及到主键本身),如果对应的主键在子表中已经被数据所引用,那么就不允许操作.

    外键条件

    1.外键要存在:首先必须保证表的存储引擎是innodb(默认的存储引擎):如果不是innodb存储引擎,那么外键可以创建成功,但是没有约束效果
    2.外键字段的字段类型(列类型)必须与父表的主键类型完全一致
    3.一张表中外键的名字不能重复
    4.增加外键的字段(数据已经存在),必须保证数据与父表主键要求对应

    外键约束
    所谓外键约束:就是指外键的作用
    之前所讲的外键作用:是默认的作用,其实可以通过对外键的需求,进行定制操作
    外键约束有三种约束模式:都是针对父表的约束
    District:严格模式(默认的),父表不能删除或者更新一个已经被子表数据引用的记录
    Cascade:级联模式:父表的操作,对应子表关联的数据也跟着操作
    Set null:置空模式:父表的操作之后,子表对应的数据(外键字段)被置空

    通常的一个合理的做法(约束模式):删除的时候字表置空,更新的时候子表级联操作
    指定模式的语法
    foreign key(外键字段) references 父表(主键字段) on delete set null update cascade;

     

    级联更新

    删除操作 :置空

    删除置空的前提条件:外键字段允许为空(如果不满足条件,外键无法创建)
    可控性:通常在实际开发中,很少使用外键来处理

     

     

     

     

     

     

     

     

  • 相关阅读:
    Qt 3D教程(二)初步显示3D的内容
    linux关于ftp查看不到文件列表的问题
    Mahout推荐算法API具体解释【一起学Mahout】
    GBK编码具体解析(附GBK码位分布图)
    HTML5实战与剖析之媒体元素(3、媒体元素的事件及方法)
    CentOS添加swap分区
    Transaction: atomicity, consistency, separability, persistence
    redis ins 调试
    jemalloc/jemalloc.h: No such file or directory
    MySQL表设计基础
  • 原文地址:https://www.cnblogs.com/sunhao96/p/7941064.html
Copyright © 2020-2023  润新知