MySQL外键(详解)

70 篇文章 0 订阅
67 篇文章 0 订阅

MySQL外键(详解)

什么是外键:
外键是指引用另外一个表中的一列或多列数据,被引用的列应该具有主键约束或者唯一性约束(简单来说外键是另一个表的主键或者唯一约束)。外键可以有重复的, 可以是空值,用来建立和加强两个表数据之间的连接
在这里插入图片描述

一、主外键关系
在上图上涉及的两个表中,学生信息表 (stuInfo)为主表,学生
成绩表(score)为从表;那么主从表之间有什么关系呢?

1、当主表中没有对应的记录时,不能将记录添加到子表
--------学生成绩表中不能出现学生信息表中没有的学号

2、不能更改主表中的值而导致子表中的记录孤立
--------学生信息表中的id变化了,学生成绩表中的id也要随着发生改变

3、子表存在与主表对应的记录,不能从主表中删除该行
--------不能把部门表中的数据删除

4、删除主表前,先删子表
--------先删除成绩表、后删除学生信息表

二、外键的使用
外键的使用需要满足下列的条件:
1、两张表必须都是InnoDB表,并且它们没有临时表。

2、建立外键关系的对应列必须具有相似的InnoDB内部数据类型。

3、建立外键关系的对应列必须建立了索引。

创建外键的两种方式:
方式一:在创建表的时候进行添加
方式二:表已经创建好了,继续修改表的结构来添加外键。

在创建表的时候添加外键
表1:

create table stuInfo(	
		Scode int primary key,   --学生的学号
		Sname char(10),    --学生的姓名
		Saddress varchar(50),    --学生的住址
		Sgrade int,    --学生所在班级
		Semail varchar(50),    --学生的邮箱地址
		Sbrith date	
)DEFAULT CHARSET='utf8';	

表2:

create table score(
studentID	int,
coureseID int,	
score int,	
scoreID int primary key,	
foreign	key(studentID) references stuInfo(Scode)  --添加外键 )
DEFAULT charset='utf8';

建表以后添加外键:
语法:alter table 表名称 add foreign key (列名称) references
关联表名称(列名称);
例:

alter table stuInfo	add foreign key (scode) references score(studentID);

三、删除外键
语法:alter table 表名称 drop foreign key 外键名称;
例:

alter table score drop foreign key score_ibQk_1;	

注意:如果没有在建表的时候标明外键名称,
可以通过:

show create table 表名;

进行查看外键名称


请添加图片描述

感谢每一个认真阅读我文章的人!!!
如果下面这些资料用得到的话可以直接拿走:

1、自学开发或者测试必备的完整项目源码与环境

2、测试工作中所有模板(测试计划、测试用例、测试报告等)

3、软件测试经典面试题

4、Python/Java自动化测试实战.pdf

5、Jmeter/postman接口测试全套视频获取

我个人整理了我这几年软件测试生涯整理的一些技术资料,包含:电子书,简历模块,各种工作模板,面试宝典,自学项目等。如果在学习或工作中遇到问题可以直接点击此链接进群询问,群里也会有大神帮忙解答,也可以手动添加群号 743262921 备注222

最后

深知大多数初中级Java工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则近万的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《Java开发全套学习资料》送给大家,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

小编已加密:aHR0cHM6Ly9kb2NzLnFxLmNvbS9kb2MvRFVrVm9aSGxQZUVsTlkwUnc==出于安全原因,我们把网站通过base64编码了,大家可以通过base64解码把网址获取下来。

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值