zoukankan      html  css  js  c++  java
  • 我对外键的回忆

    添加外键:(注意:constraint前面没得add,add是alter的时候才会有的)
    CONSTRAINT stu_class_fk
    FOREIGN KEY(stu_id)
    REFERENCES stu_class(id)
    ON UPDATE CASCADE
    ON DELETE CASCADE


    在添加外键的时候,必须保证外键到的主表的字段为unique的,或者是primary key。






    CREATE TABLE stu_class(
    id INT  UNIQUE

    );


    CREATE TABLE student(
    class_id INT,
    CONSTRAINT stu_class_fk
    FOREIGN KEY(class_id)
    REFERENCES stu_class(id)
    ON UPDATE CASCADE
    ON DELETE CASCADE
    );




    INSERT INTO stu_class VALUE(1), (2), (3);
    INSERT INTO student VALUE(1), (1), (2), (2), (3), (3); 


    -- 删除主表中的数据,因为级联删除,从表中的数据没有了。
    DELETE FROM stu_class WHERE id = 1;


    -- 删除从表中的数据,主表并不会受到影响
    DELETE FROM student WHERE class_id = 2;


    -- 修改主表中的数据,因为级联修改,从表中的数据一起修改了。
    UPDATE stu_class SET id = 5 WHERE id = 3;


    -- 从表中的数据是不能修改的!
    UPDATE student SET id = 2 WHERE id = 5;
    -- 包括很多时候我们设置了主键自增长,没有办法truncate从表中的自增长记录
    -- 只能通过先设置外键为0,再设置外键为1
    -- 额外补充:其实在mysql中是没有boolean 类型的,所有boolean的值都是被转化成0和1:0f,1t。
    SET FOREIGN_KEY_CHECKS = 0;
    SET FOREIGN_KEY_CHECKS = 1;

  • 相关阅读:
    设置允许跨域访问
    设计模式学习笔记(1)——单例模式
    yii2 request文件简介
    YII2 添加全局自定义函数
    第2章 查询基础
    第1章 数据库和SQL
    第0章 绪论
    用户贷款风险预测—特征提取
    用户贷款风险预测—数据探索
    Python 数据分析—画图
  • 原文地址:https://www.cnblogs.com/mzywucai/p/11053494.html
Copyright © 2011-2022 走看看