您当前的位置: 首页 >  sql

网易测试开发猿

暂无认证

  • 2浏览

    0关注

    221博文

    0收益

  • 0浏览

    0点赞

    0打赏

    0留言

私信
关注
热门博文

MySQL外键(详解)

网易测试开发猿 发布时间:2021-11-17 19:24:00 ,浏览量:2

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 表名;

进行查看外键名称

关注
打赏
1665054478
查看更多评论
立即登录/注册

微信扫码登录

0.0450s