本文作者:kris

关于MySQL外键的简单学习教程-mysql外键是什么意思

kris 2025-01-15 15:40:58 2
关于MySQL外键的简单学习教程-mysql外键是什么意思摘要: mysql外键怎么刷?1、在CREATE TABLE语句中,通过FOREIGN KEY关键字来添加外键;2、在ALTER TABLE语句中,通过ADD和FOREIGN KEY关键字...

mysql外键怎么刷?

1、在CREATE TABLE语句中,通过FOREIGN KEY关键字来添加外键;

2、在ALTER TABLE语句中,通过ADD和FOREIGN KEY关键字来添加外键。

如何在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外键是什么意思

MySQL使用外键实现级联删除与更新的方法?

设定外键为级联删除就可以了。alter table B add constraint fk_ID foreign key (ID) references A(ID) on delete cascade;这样只需:delete from A where ID=nnnn; 就可以自动删除对应B表内容了。通过外键无法实现同步更新。

mysql一张表多个外键sql怎么写?

abc这3张表在设计的时候就应该是把主键和外键设好的吧,所以这和插入数据时所使用的语句是没有什么关系的,而数据的对应关系就是这样的吧A--〉aB--〉b,C--〉c。a,b,c表只多了个时间字段,那你给这个字段设默认值的时候设为getdate()就可以了不用人为的去插入时间了~用简单的SQL就可以了比如SELECT*INTOaFROMA

MySQL中被其他表外键引用的字段为什么不能添加主键自增?

一个表的外键必须是另外一个表的主键 每一个表不是必须得有一个自增主键id的,比如学生表,可以设置学号为主键,这样在选课表中可以设置学号为外键,引用学生表中的学号

文章版权及转载声明

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

阅读
分享