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

 更新时间:2021年01月17日 09:14:39   作者:Spike Bo  
这篇文章主要给大家介绍了关于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的体系结构及存储引擎图解

    关于MySQL的体系结构及存储引擎图解

    这篇文章主要介绍了关于MySQL的体系结构及存储引擎图解,MySQL整体的逻辑结构可以分为4层,客户层、服务层、存储引擎层、数据层,需要的朋友可以参考下
    2023-05-05
  • MYSQL实现连续签到功能断签一天从头开始(sql语句)

    MYSQL实现连续签到功能断签一天从头开始(sql语句)

    这篇文章主要介绍了MYSQL实现连续签到功能断签一天从头开始,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2017-05-05
  • MySQL BETWEEN AND踩坑记录

    MySQL BETWEEN AND踩坑记录

    这篇文章主要介绍了MySQL BETWEEN AND踩坑记录,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-07-07
  • 修改MySQL数据库引擎为InnoDB的操作

    修改MySQL数据库引擎为InnoDB的操作

    这篇文章主要介绍了修改MySQL数据库引擎为InnoDB的操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-12-12
  • SQL实战演练之网上商城数据库用户信息数据操作

    SQL实战演练之网上商城数据库用户信息数据操作

    一直认为,扎实的SQL功底是一名数据分析师的安身立命之本,甚至可以称得上是所有数据从业者的基本功。当然,这里的SQL绝不单单是写几条查询语句那么简单,接下来请跟着小编通过案例项目进一步提高SQL的能力吧
    2021-10-10
  • mysql 双向同步的键值冲突问题的解决方法分享

    mysql 双向同步的键值冲突问题的解决方法分享

    多主互备和主从复制有一些区别,因为多主中都可以对服务器有写权限,所以设计到自增长重复问题
    2011-09-09
  • FROM_UNIXTIME 格式化MYSQL时间戳函数

    FROM_UNIXTIME 格式化MYSQL时间戳函数

    对MYSQL没有进行过深入的研究,基础知识匮乏,一遇到问题只能手册,看来要把MYSQL的学习安排进时间表了。
    2011-04-04
  • Spark SQL常见4种数据源详解

    Spark SQL常见4种数据源详解

    这篇文章主要介绍了Spark SQL常见4种数据源(详细),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,,需要的朋友可以参考下
    2019-06-06
  • MySQL大小写敏感导致的问题分析

    MySQL大小写敏感导致的问题分析

    在本篇内容里小编给大家整理了关于MySQL大小写敏感导致的问题的详细分析,有兴趣的朋友们可以学习参考下。
    2019-06-06
  • 详解MySQL 表中非主键列溢出情况监控

    详解MySQL 表中非主键列溢出情况监控

    这篇文章主要介绍了详解MySQL 表中非主键列溢出情况监控,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-04-04

最新评论