• 我对外键的回忆


    添加外键:(注意: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;

  • 相关阅读:
    git注册和基本命令
    thinkphp概述2
    thinkphp概述
    PHP基础知识总结
    phpmyadmin教程
    开发环境wamp3.06 + Zend studio 12 调试配置
    PHP标记风格,编码规范
    PHP开发工具 zend studio
    php与ajax技术
    可变参模板template
  • 原文地址:https://www.cnblogs.com/mzywucai/p/11053494.html
Copyright © 2020-2023  润新知