MySQL(七)—— 外键使用

本文介绍了MySQL中外键的概念、如何增加、修改和删除外键,以及外键的作用和条件。外键用于关联两张表,确保数据的一致性和完整性。在创建外键时需注意存储引擎为InnoDB,字段类型与父表主键一致。外键约束有严格、级联和置空三种模式,实际开发中因考虑PHP数据可控性,外键使用较少。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

目录

增加外键

修改外键&删除外键

外键作用

外键条件

外键约束


外键

外键: foreign key, 外面的键(键不在自己表中): 如果一张表中有一个字段(非主键)指向另外一张表的主键,那么将该字段称之为外键.

增加外键

外键可以在创建表的时候或者创建表之后增加(但是要考虑数据的问题).

一张表可以有多个外键.

创建表的时候增加外键: 在所有的表字段之后,使用foreign key(外键字段) references 外部表(主键字段)

-- 创建主键表
create table my_pri(
id int primary key auto_increment,
name varchar(20) not null
)charset utf8;

-- 创建外键表
create table my_foreign1(
id int primary key auto_increment,
name varchar(20) not null,
c_id int,
-- 增加外键
foreign key(c_id) references my_pri(id)
)charset utf8;

在新增表之后增加外键: 修改表结构

Alter table 表名 add [constraint 外键名字] foreign key(外键字段) references 父表(主键字段);

-- 创建表
create table my_foreign2(
id int primary key auto_increment,
name varchar(20) not null,
c_id int
)charset utf8;

-- 增加外键
alter table my_foreign2 add
-- 指定外键名
constraint foreign2_pri_1
-- 指定外键字段
foreign key(c_id)
-- 引用父表主键
references my_pri(id);

修改外键&删除外键

外键不可修改: 只能先删除后新增.

删除外键语法

Alter table 表名 drop foreign key 外键名; -- 一张表中可以有多个外键,但是名字不能相同

-- 删除外键 my_foreign1_ibfk_1是表my_foreign1的外键名
alter table my_foreign1 drop foreign key my_foreign1_ibfk_1;

外键作用

外键默认的作用有两点: 一个对父表,一个对子表(外键字段所在的表)

对子表约束: 子表数据进行写操作(增和改)的时候, 如果对应的外键字段在父表找不到对应的匹配: 那么操作会失败.(约束子表数据操作)

对父表插入数据进行查询

-- 插入数据
insert into my_pri values(1,'MYSQL'),(2,'PHP'),(3,'JAVA');
-- 查询数据
select * from my_pri;

-- 插入数据:外键字段在父表中不存在
insert into my_foreign2 values(null,'老林',4); -- 报错,没有主键4
insert into my_foreign2 values(null,'老赵',1); 
insert into my_foreign2 values(null,'老王',2); 
insert into my_foreign2 values(null,'老刘',2); 

 对父表约束: 父表数据进行写操作(删和改: 都必须涉及到主键本身), 如果对应的主键在子表中已经被数据所引用, 那么就不允许操作

-- 查询数据
select * from my_pri;
select * from my_foreign1;

-- 更新父表记录
update my_pri set id = 4 where id = 1; -- 失败: id=1记录已经被my_foreign1引用
update my_pri set id = 4 where id = 3; -- 可以: 没有引用

外键条件

  1. 外键要存在: 首先必须保证表的存储引擎是innodb(默认的存储引擎): 如果不是innodb存储引擎,那么外键可以创建成功,但是没有约束效果.
  2. 外键字段的字段类型(列类型)必须与父表的主键类型完全一致.
  3. 一张表中的外键名字不能重复.
  4. 增加外键的字段(数据已经存在),必须保证数据与父表主键要求对应.

外键约束

所谓外键约束: 就是指外键的作用.

之前所讲的外键作用: 是默认的作用; 其实可以通过对外键的需求, 进行定制操作.

外键约束有三种约束模式: 都是针对父表的约束

District: 严格模式(默认的), 父表不能删除或者更新一个已经被子表数据引用的记录

Cascade: 级联模式: 父表的操作, 对应子表关联的数据也跟着被删除

Set null: 置空模式: 父表的操作之后,子表对应的数据(外键字段)被置空

通常的一个合理的做法(约束模式): 删除的时候子表置空, 更新的时候子表级联操作

指定模式的语法

Foreign key(外键字段) references 父表(主键字段) on delete set null on update cascade;

-- 创建外键: 指定模式: 删除置空,更新级联
create table my_foreign3(
id int primary key auto_increment,
name varchar(20) not null,
c_id int,
-- 增加外键
foreign key(c_id)
-- 引用表
references my_pri(id)
-- 指定删除模式
on delete set null
-- 指定更新默认
on update cascade)charset utf8;

更新操作: 级联更新

删除操作: 置空

删除置空的前提条件: 外键字段允许为空(如果不满足条件,外键无法创建)

外键虽然很强大, 能够进行各种约束: 但是对于PHP来讲, 外键的约束降低了PHP对数据的可控性: 通常在实际开发中, 很少使用外键来处理.

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值