欢迎来到代码驿站!

Mysql

当前位置:首页 > 数据库 > Mysql

MySQL中外键的创建、约束以及删除

时间:2021-04-16 08:22:40|栏目:Mysql|点击:

前言

在MySQL 3.23.44版本后,InnoDB引擎类型的表支持了外键约束。

外键的使用条件:

1.两个表必须是InnoDB表,MyISAM表暂时不支持外键(据说以后的版本有可能支持,但至少目前不支持);

2.外键列必须建立了索引,MySQL 4.1.2以后的版本在建立外键时会自动创建索引,但如果在较早的版本则需要显示建立;

3.外键关系的两个表的列必须是数据类型相似,也就是可以相互转换类型的列,比如int和tinyint可以,而int和char则不可以;

外键的好处:可以使得两张表关联,保证数据的一致性和实现一些级联操作;

一、外键的创建

语法一:后续添加方法

alter table 表名 add constraint 约束名 foreign key(当前表中约束的字段) references 主表表名(要约束的字段名);
alter table student add constraint fk_class_student foreign key(cls_id) class(cls_id) on update cascade on delete no action;

语法二:创建表的方法

CREATE TABLE student(
sid int PRIMARY KEY,
cls_id int not null,
sname varchar(10) not null,
constraint fk_class_student foreign key(cls_id) references class(cls_id) on update cascade on delete no action
)ENGINE=InnoDB DEFAULT CHARSET=utf8;

一个额外点:

SHOW CREATE TABLE class

可以查询表的建表信息

在这里插入图片描述

CREATE TABLE `class` (
 `cls_id` int NOT NULL,
 `cls_name` varchar(15) NOT NULL,
 PRIMARY KEY (`cls_id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8

下面的演示我们就使用刚刚创建的这个学生表和班级表

内容如下

在这里插入图片描述

在这里插入图片描述

二,关于四种约束方式

在父表上进行update/delete操作时,子表的操作类型

  1. CASCADE 子表会删除包含与已删除键值有参照关系的所有数据
  2. SET NULL 父表delete、update的时候,子表会将关联记录的外键字段所在列设为null
  3. RESTRICT 拒绝有关联关系的字段的删除要求(这是默认设置,也是最安全的设置)
  4. NO ACTION 和RESTRICT 类似

以我们刚刚设置的外键为例(on update cascade on delete no action)

当我们尝试进行删除操作时

delete from class WHERE cls_id=1

结果如下

在这里插入图片描述

可以看到由于外键约束中on delete no action的存在,不允许对主表进行删除操作。但是子表可以

delete from student WHERE cls_id=1

在这里插入图片描述

当我们对父表的关联键进行更新操作时,由于on update cascade的存在,可以正常更新

UPDATE class set cls_id=4 where cls_id=1

在这里插入图片描述

并且随着主表的更新,子表中的外键字段也进行了更新

在这里插入图片描述

三,删除外键的方法

alter table 子表名 drop foreign key 外键约束名
alter table student drop foreign key fk_class_student

当我们将外键删除之后,父表的操作就变得可以正常进行了

在这里插入图片描述

总结

上一篇:关于MYSQL 远程登录的授权方法 命令

栏    目:Mysql

下一篇:mysql 5.6.26 winx64安装配置图文教程(一)

本文标题:MySQL中外键的创建、约束以及删除

本文地址:http://www.codeinn.net/misctech/102084.html

推荐教程

广告投放 | 联系我们 | 版权申明

重要申明:本站所有的文章、图片、评论等,均由网友发表或上传并维护或收集自网络,属个人行为,与本站立场无关。

如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

联系QQ:914707363 | 邮箱:codeinn#126.com(#换成@)

Copyright © 2020 代码驿站 版权所有