1. 背景

* MySQL有两种常用的引擎类型MyISAM和InnoDB。目前只有InnoDB引擎类型支持外键约束。

* 本表的列必须与外键类型相同, 外键必须是外表的唯一键(或主键)。

* 设置外建的列不能设置 NO NULL 字段属性。

2. 外建作用

* 使两张表形成关联,外键只能引用外表中的列的值

* 保持数据一致性,完整性,控制存储在外键表中的数据

3. 外键实验 [ 员工 --> 部门 ]

* 创建外键依赖的外表 departments

mysql> CREATE TABLE departments(-> id BIGINT PRIMARY KEY NOT NULL AUTO_INCREMENT,-> name VARCHAR(64) NOT NULL-> )ENGINE=INNODB CHARSET=utf8mb4;
Query OK, 0 rows affected (0.05 sec)

* 创建员工表 empoyees, 并建立外键

指定外键关键字: FOREIGN KEY(列名)

引用外键关键字: REFERENCES <外键表名>(外键列名) 

事件触发限制:  [默认] no action

ON DELETE  SET NULL   当外表字段删除时,本表设置为NULL(空值) [ 不推荐设置此荐 ]

ON UPDATE CASCADE   当外表字段更新时,本表外键级联更新

ON DELETE/UPDATE SET DEFAULT 当有事件触发时,设置为默认值

    ON DELETE/UPDATE RESTRICT      当有事件触发时,限制外表中的外键改动

mysql> CREATE TABLE empoyees( -> id BIGINT PRIMARY KEY NOT NULL AUTO_INCREMENT,-> sex ENUM('M', 'F') NOT NULL,-> age INT NOT NULL,-> department BIGINT,-> FOREIGN KEY(department) -> REFERENCES departments(id) -> ON DELETE SET NULL-> ON UPDATE CASCADE-> )ENGINE=INNODB CHARSET=utf8mb4;
Query OK, 0 rows affected (0.12 sec)

* 对部门表 departments 插入数据

mysql> INSERT INTO departments SELECT NULL, 'dev';
Query OK, 1 row affected (0.01 sec)
Records: 1  Duplicates: 0  Warnings: 0mysql> INSERT INTO departments SELECT NULL, 'test';
Query OK, 1 row affected (0.01 sec)
Records: 1  Duplicates: 0  Warnings: 0mysql> INSERT INTO departments SELECT NULL, 'ops';
Query OK, 1 row affected (0.01 sec)
Records: 1  Duplicates: 0  Warnings: 0

* 查看部门表数据

mysql> SELECT * FROM departments;
+----+------+
| id | name |
+----+------+
|  1 | dev  |
|  2 | test |
|  3 | ops  |
+----+------+
3 rows in set (0.00 sec)

* 插入正常数据 (部门编号存在于部门表中)

mysql> INSERT INTO empoyees SELECT NULL, 'M', 22, 2;
Query OK, 1 row affected (0.01 sec)
Records: 1  Duplicates: 0  Warnings: 0mysql> SELECT * FROM empyees;
ERROR 1146 (42S02): Table 'mytest.empyees' doesn't exist
mysql> SELECT * FROM empoyees;
+----+-----+-----+------------+
| id | sex | age | department |
+----+-----+-----+------------+
|  1 | M   |  22 |          2 |
+----+-----+-----+------------+
1 row in set (0.01 sec)

* 插入非正常数据 (部门编号不存在于部门表中) [ 部门表中不存在id为4的列 ]

mysql> INSERT INTO empoyees SELECT NULL, 'M', 22, 4;
ERROR 1452 (23000): Cannot add or update a child row: a foreign key constraint fails (`mytest`.`empoyees`, CONSTRAINT `empoyees_ibfk_1` FOREIGN KEY (`department`) REFERENCES `departments` (`id`) ON DELETE SET NULL ON UPDATE CASCADE)

* 修改部门表数据 [ 员工表中已有数据关联部门表中id为2 ]

mysql> SELECT * FROM empoyees;
+----+-----+-----+------------+
| id | sex | age | department |
+----+-----+-----+------------+
|  1 | M   |  22 |          2 |
+----+-----+-----+------------+
1 row in set (0.01 sec)mysql> UPDATE departments SET id = 4 WHERE id=2;
Query OK, 1 row affected (0.04 sec)
Rows matched: 1  Changed: 1  Warnings: 0mysql> SELECT * FROM empoyees;
+----+-----+-----+------------+
| id | sex | age | department |
+----+-----+-----+------------+
|  1 | M   |  22 |          4 |
+----+-----+-----+------------+
1 row in set (0.01 sec)

* 删除部门表数据 [ 员工表中已有数据关联部门表中id为4 ]

mysql> SELECT * FROM empoyees;
+----+-----+-----+------------+
| id | sex | age | department |
+----+-----+-----+------------+
|  1 | M   |  22 |          2 |
+----+-----+-----+------------+
1 row in set (0.01 sec)mysql> DELETE FROM departments WHERE id = 4;
Query OK, 1 row affected (0.01 sec)mysql> SELECT * FROM empoyees;
+----+-----+-----+------------+
| id | sex | age | department |
+----+-----+-----+------------+
|  1 | M   |  22 |       NULL |
+----+-----+-----+------------+
1 row in set (0.00 sec)

4. 总结

以需求驱动技术,技术本身没有优略之分,只有业务之分。

转载于:https://blog.51cto.com/lisea/1943689

MySQL DDL操作--------外键最佳实战相关推荐

  1. mysql外键约束案例_详解MySQL中的外键约束问题

    使用MySQL开发过数据库驱动的小型web应用程序的人都知道,对关系数据库的表进行创建.检索.更新和删除等操作都是些比较简单的过程 .理论上,只要掌握了最常见的SQL语句的用法,并熟悉您选择使用的服务 ...

  2. oracle+cascade=gt;true,mysql数据库主外键级联删除脚本RESTRICT -- CASCADE

    在项目中,我们一般在数据库设计的时候做主外键关联设计,要么就不做.但是这样不符合规范,呵呵. 建立主外键关系的时候,默认是不能级联删除的.而出现往往在删除主表的数据时报错, 需要先删除从表然后再删除主 ...

  3. mysql建表 外键_mysql建表外键怎么设

    mysql建表外键怎么设 mysql建表时设置外键的方法:在"CREATE TABLE"语句中,通过"[CONSTRAINT ] FOREIGN KEY 字段名 [,字段 ...

  4. mysql级联删除外键约束_玩转MySQL的外键约束之级联删除篇

    [IT168 文档]如今,许多关系型数据库管理系统都提供了外键约束这一强大的功能特性,它能够帮助我们自动地触发指定的动作,诸如删掉.更新数据库表的记录等,从而维护各数据库表之间预定义的关系.本文将演示 ...

  5. mysql中的外键约束_MySQL外键约束

    在本教程中,您将了解MySQL外键(foreign key)以及如何在MySQL中创建,添加和删除外键约束. MySQL外键简介 外键表示一个表中的一个字段被另一个表中的一个字段引用.外键对相关表中的 ...

  6. Mysql无法创建外键的原因

    在Mysql中创建外键时,经常会遇到问题而失败,这是因为Mysql中还有很多细节需要我们去留意,我自己总结并查阅资料后列出了以下几种常见原因. 1.  两个字段的类型或者大小不严格匹配.例如,如果一个 ...

  7. mysql不能删除外键吗,MySQL不能删除外键约束所需的索引

    MySQL不能删除外键约束所需的索引 我需要改变现有的数据库添加一列. 因此我也想更新UNIQUE字段来包含这个新列. 我试图删除当前的索引,但不断收到错误MySQL Cannot drop inde ...

  8. mysql setnull_1、Mysql无法创建外键的原因 2、MySql 外键约束 之CASCADE、SET NULL、RESTRICT、NO ACTION分析和作用...

    在Mysql中创建外键时,经常会遇到问题而失败,这是因为Mysql中还有很多细节需要我们去留意,我自己总结并查阅资料后列出了以下几种常见原因. 1.  两个字段的类型或者大小不严格匹配.例如,如果一个 ...

  9. Mysql学习总结(19)——Mysql无法创建外键的原因

    在MySQL中创建外键时,经常会遇到问题而失败,这是因为Mysql中还有很多细节需要我们去留意,我自己总结并查阅资料后列出了以下几种常见原因. 1.  两个字段的类型或者大小不严格匹配.例如,如果一个 ...

最新文章

  1. java中抽象接口_一篇文章让你彻底理解java中抽象类和接口
  2. AI综述专栏 | 神经科学启发的人工智能
  3. [国际A类会议] 2018最最最顶级的人工智能国际峰会汇总!CCF推荐!
  4. Java 单例模式探讨
  5. Linux上安装JDK+Tomcat
  6. 如何学习(记住)linux命令(常用选项)
  7. laravel 安装后500错误
  8. Rust性能分析-迭代器的enumerate方法是否会影响程序性能
  9. 偷窥微信原创保护规则,优先体验付费阅读系统功能
  10. Vert.x Web
  11. 中国黑客常用的八种工具及其防御方法(转)
  12. python怎么过滤停用词_第6天:文本处理流程——停用词的过滤、正则化操作
  13. Scary Movie 4
  14. [转]Cookie详解
  15. ie上直接打开服务器word文档,win7 ie11直接打开word
  16. 鸿蒙车载智慧屏评测,荣耀智慧屏体验评测:鸿蒙系统的智慧
  17. self-supervised text erasing with controllable image synthesis
  18. java的jre和jdk
  19. 修改Chromium源码实现HEVC/H.265 4K视频播放
  20. 联想服务器 带外管理系统,联想服务器存储成就“数图”海量应用

热门文章

  1. 需求调研计划_拆书营销管理 实施营销调研和预测需求
  2. linux ssh登录源地址限制,H3C交换机配置SSH源地址登录限制和SNMP源地址限制的方法...
  3. 以太坊智能合约开发第七篇:智能合约与网页交互
  4. Linux - Nginx安装
  5. Linux基础命令--常用命令工具
  6. 7.06 生成累计和
  7. SpringBoot开发案例之整合Dubbo提供者(二)
  8. 《大话操作系统——做坚实的project实践派》(3)
  9. 只学一点点:我的技术学习策略
  10. leetcode9 Palindrome Number 回数