• 十、外键约束FK(foreign key)


    1.定义

    a.外键涉及到的术语:外键约束、外键字段、外键值。

    b.外键约束、外键字段、外键值三者之间的关系?

    答:给某个字段添加外键约束之后,该字段称为外键字段,外键字段中的值是外键值。

    c.外键根据个数分为:单一外键、复合外键

    1>【单一外键】:给一个字段添加外键约束

    2>【复合外键】:给多个字段联合添加一个外键

    d.在同一张表中可以有多个外键存在

    2.实例

    有两张表,分别是学生表 t_student 和班级表 t_class,以 t_student 表的 classno为外键

    drop table if exists t_student;
    create table t_student(
        sno int(4) primary key auto_increment,
        sname varchar(32),
        classno int(4),
        constraint t_student_classno_fk foreign key(classno) references t_class(cno)
    );
    
    create table t_class(
        cno int(4) primary key,
        cname varchar(32)
    );

    sql数据文本

    insert into t_class(cno,cname) values(100,'高三一班');
    insert into t_class(cno,cname) values(200,'高三二班');
    insert into t_class(cno,cname) values(300,'高三三班');
    insert into t_student(sname,classno) values('张三',100);
    insert into t_student(sname,classno) values('李四',100);
    insert into t_student(sname,classno) values('王五',400);
    View Code

     请注意以下三点:

    1.外键字段可以为null,外键为空的数据也叫孤儿数据;

    2.被引用的字段必须具有unique约束;(就是references后面的字段)

    3.加入外键约束后,表分为父表和子表,以上父表是 t_class;子表是 t_student;

    创建表时先创建父表,再删除子表;插入数据时,先插入父表数据,再插入子表数据。

    总结:在一对多的关系中,多的一方可以添加外键(子表),少的一方是引用(父表)。

    a.删除外键约束

    语法:alter table 表名 drop foreign key 外键约束名;

    3.级联更新和级联删除

    用法:在添加级联更新和级联删除的时候,需要在外键约束后面添加关键字;

    注意:级联更新和级联删除要谨慎使用,因为级联操作会将数据改变或者删除【数据无价】。

    a.级联删除:on delete cascade

    定义:在删除父表数据时,级联删除子表中的数据

    b.级联更新:on update cascade

    定义:在更新父表数据时,级联更新子表中的数据

  • 相关阅读:
    解决删除镜像时image is referenced in multiple repositories
    paramiko模块的使用
    python之函数(一)
    python之控制流习题+代码
    python之控制流
    Python之逻辑运算符
    python之列表,元组,字典。
    python之常用的数据类型
    python基础语法之基础语法规则以及设置
    python环境搭建以及pycharm的安装
  • 原文地址:https://www.cnblogs.com/zheaven/p/8184424.html
Copyright © 2020-2023  润新知