• MySQL 外键约束 多表联查 联合查询


    外键约束

    外键用来让两张表的数据之间建立连接,从而保证数据的一致性和完整性。
    有一张学生表和班级表,学生表通过班级表的ID引用到该班级,从而进行关联,而通过外键约束可以保证数据的一致性完整性。
    在这里插入图片描述

    如学生ID18关联到课程ID1号,发生了关联并且使用了外键,这时删除课程表ID为1的情况下就会失败,因为有关联,这样就保证了数据的完整性。

    添加外键

    新建表时添加

    sql
    CREATE TABLE orders (
        order_id INT PRIMARY KEY,
        customer_id INT,
        order_date DATE,
        FOREIGN KEY (customer_id) REFERENCES customers(customer_id)
    );
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    已创建的表添加

    ALTER TABLE 子表名称
    ADD CONSTRAINT 外键约束名称
    FOREIGN KEY (子表外键字段)
    REFERENCES 父表名称(父表关联字段);
    
    • 1
    • 2
    • 3
    • 4

    实例

    ALTER  TABLE students ADD CONSTRAINT  students_classes FOREIGN KEY (classes) REFERENCES classes(id)
    
    • 1

    在这里插入图片描述
    这时课程表为父表,学生表为子表

    效果

    创建外键成功后,如果删除班级表,这时有学生关联着会删除失败,

    DELETE   FROM  classes  WHERE  id=1
    
    • 1

    在这里插入图片描述
    翻译过来
    在这里插入图片描述
    删除失败,外键约束

    删除外键

    ALTER TABLE students DROP FOREIGN KEY  外键名称
    
    • 1

    外键行为

    NO ACTION(默认)

    当在父表中删除/更新对应记录时,首先检查该记录是否有对应外键,如果有则不允许删除/更新。(与RESTRICT一致)

    RESTRICT

    当在父表中删除/更新对应记录时,首先检查该记录是否有对应外键,如果有则不允许删除/更新。(与NOACTION 致)

    这两个是一样的

    CASCADE

    当在父表中删除/更新对应记录时,首先检查该记录是否有对应外键,如果有则也删除/更新外键在子表中的记录。也就是说会删除子表关联的数据

    SET NULL

    当在父表中删除对应记录时,首先检查该记录是否有对应外键,如果有则设置子表中该外键值为nul(这就要求该外键允许取nul)。删除父表的数据时候子表关联的数据会设置成null

    SET DEFAULT

    父表有变更时,子表将外键列设置成一个默认的值(Innodb不支持)

  • 相关阅读:
    多线程案例(线程池篇)
    大数据开发(Spark面试真题-卷四)
    在Ubuntu上安装最新的neovim(with LinuxBrew)
    深入理解synchronized背后的原理
    07【MyBatis连接池与事务管理】
    基于shiro+redis缓存的session共享方案
    1336_FreeRTOS中一组队列辅助接口函数的实现分析
    mkv视频格式转换mp4格式
    渗透测试-干货 | 80篇+网络安全面试经验帖(面试篇)
    Linux基础IO
  • 原文地址:https://blog.csdn.net/dpc5201314/article/details/136403416