本文作者:kris

详解MySQL 外键约束-mysql中的外键约束

kris 2025-01-19 21:00:10 2
详解MySQL 外键约束-mysql中的外键约束摘要: mysql外键约束怎么写?MySQL外键约束可以通过在创建表或修改表时添加FOREIGN KEY关键字来实现。语法为: FOREIGN KEY (列名) REFERENCES 目标...

mysql外键约束怎么写?

MySQL外键约束可以通过在创建表或修改表时添加FOREIGN KEY关键字来实现。语法为: FOREIGN KEY (列名) REFERENCES 目标表(列名) ON DELETE CASCADE/SET NULL/RESTRICT。其中,列名为当前表中的列名,目标表为引用的外部表名,ON DELETE CASCADE/SET NULL/RESTRICT表示当删除外部表中的记录时,当前表中的记录应该如何处理。CASCADE表示级联删除,SET NULL表示将当前表中相关记录的外键值设为NULL,RESTRICT表示禁止删除。

如何在MySQL中设置外键约束以及外键的作用?

外键的作用:外键主要用来保证数据的完整性和一致性,便于关系数据的日常维护。是两张关系表中的主表数据修改或删除是自动操作字表中的数据。(外键并不是费用不可,通过程序逻辑上的操作完全可以替代)

注意事项:

1、两个表必须是InnoDB表,MyISAM表暂时不支持外键

2、如果在较早的版本(4.1.2以前)则需要显示建立外键列必须建立了索引

3、外键关系的两个表的列必须是数据类型相似。比如int和tinyint可以,而int和char则不可以

外键约束使用最多的两种情况:

1)父表更新时子表也更新,父表删除时如果子表有匹配的项,删除失败;

2)父表更新时子表也更新,父表删除时子表匹配的项也删除。

前一种情况,在外键定义中,用ON UPDATE CASCADE ON DELETE RESTRICT;

后一种情况,可以使用ON UPDATE CASCADE ON DELETE CASCADE。

举例说明:用最常见的场景:文章表,和分类表;

创建外键约束:

ALTER TABLE `article`ADD CONSTRAINT `fk_1` FOREIGN KEY (`category_id`) REFERENCES `category` (`id`);

现在删除分类表中的一条数据:

文章表添加一条数据:

这样是不是就保证了文章表里的分类ID 都能在分类表找到对应的名称啦?

下面我们删除外键重新创建:


详解MySQL 外键约束-mysql中的外键约束


详解MySQL 外键约束-mysql中的外键约束


详解MySQL 外键约束-mysql中的外键约束


详解MySQL 外键约束-mysql中的外键约束


详解MySQL 外键约束-mysql中的外键约束


详解MySQL 外键约束-mysql中的外键约束

外键约束怎么写?

外键约束可以通过在创建表的时候使用FOREIGN KEY关键字指定外键列,并且使用REFERENCES关键字指定参照表和列。例如,创建一个名为orders的表,其中包含一个指向customers表的外键列customer_id,可以像这样写:
CREATE TABLE orders (
order_id int PRIMARY KEY,
customer_id int,
order_date date,
FOREIGN KEY (customer_id) REFERENCES customers(customer_id)
);
这样可以确保在orders表中的customer_id列的值必须在customers表的customer_id列中存在,从而实现了外键约束。

oracle的外键约束有用吗?

当然有用,这样可以防止引用无效数据。

比如,一个学校的管理数据库,已经有了班级表,其主键是班级编码。现在要建立学生学籍档案表,每个学生都必然归属于一个班级,就可以为学生学籍档案表增加外键约束,要求该表的班级字段与班级表的编码字段对应,其值必须是存在于班级表中的主键。

文章版权及转载声明

作者:kris本文地址:https://www.damoyx.com/p/24962.html发布于 2025-01-19 21:00:10
文章转载或复制请以超链接形式并注明出处大漠游侠网

阅读
分享