MySQL快速入门06----实体关系 & 外键

本文介绍了MySQL中的一对一、一对多和多对多的实体关系,并详细讲解了外键的概念及其在数据完整性中的作用。外键的级联操作如cascade(级联更新或删除)、set null(设为空)和restrict(拒绝操作)被逐一阐述。

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

一 实体关系


在数据库中,常用的实体关系有三种: 一对一、一对多和多对多。

1.1 一对一的实体关系




如果记录的主键值等于另一个关系内记录的主键值,我问称之为一对一的实体关系。

一对一的实体关系(1:1)使得两个表保存的实体之间数据是对等的。


如:一个学生有基本信息和详细信息。


1.2 一对多的实体关系



一对多的实体关系(1:N),A实体对应多个B实体。

如:一个班级内有很多学生,而且一个学生只属于一个班级。

设计:在多的那端,增加一个字段,用于指向该实体所属的另外的实体的标识。

1.3 多对多的实体关系




多对多的关系(M:N),A实体对应多个B实体,同时一个B实体也对应多个A实体。

例:一个讲师可以给多个班级授课。同时一个班级可以由多个来授课

设计:利用一个中间表,标识实体之间的对应关系,中间表的每个记录,标识一个关系,其 实质还是一对多的关系



 二 外键

概念:如果一个实体的(student)的某个字段(student:class_id),指向(引用)另个实体(class)的主键(class:class_id),就称 Student实体的class_id是外键。



被指向的实体,称之为 主实体(主表),也叫父实体(父表)。class
负责指向的实体,称之为 从实体(从表),也叫子实体(子表)。Student

作用:
  • 保证数据的完整性。
  • 用于约束处于关系内的实体。
  • 增加子表记录时,是否有与之对应的父表记录。
  • 在删除或者更新主表记录时,从表应该如何处理相关的记录。

2.1 定义一个外键


MySQL中,可以对
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值