MySQL——多表操作(二)操作关联表(1)关联关系

在实际开发中,需要根据实体的内容设计数据表,实体间会有各种关联关系。所以根据实体设计的数据表之间也存在着各种关联关系,MySQL中数据表的关联关系有种,具体如下。

1.多对一

多对一是数据表中最常见的一种关系。比如,员工与部门之间的关系,一个部门可以有多个员工,而一个员工不能属于多个部门,也就是说部门表中的一行在员工表中可以有许多匹配行,但员工表中的一行在部门表中只能有一个匹配行。

我们知道表之间的关系是通过外键建立的。在多对一的表关系中,应该将外键建在多的一方,否则会造成数据的冗余

2. 多对多

多对多也是数据表中的一种关系。比如学生与课程之间的关系,一个学生可以选择多门课程,当然一门课程也供多个学生选择,也就是说学生表中的一行在课程表中可以有许多匹配行,课程表中的一行在学生表中也有许多匹配行。

通常情况下,为了实现这种关系需要定义一张中间表(称为连接表),该表会存在两个外键,分别参照课程表和学生表。在多对多的关系中,需要注意的是,连接表的两个外键都是可以重复的,但是两个外键之间的关系是不能重复的,所以这两个外键又是连接表的联合主键。

3. 一对一

一对一关系在实际生活中比较常见,例如人与身份证之间就是一对一的关系,一个人对应一张身份证,一张身份证只能匹配一个人。那么,一对一关系的两张表如何建外键?

首先,要分清主从关系。从表需要主表的存在才有意义,身份证需要人的存在才有意义。因此人为主表,身份证为从表。要在身份证表中建立外键。由实际经验可知,份证中的外键必须是非空唯一的,因此通常会直接用从表(表身份证)中的主键作为外键。

需要注意的是,这种关系在数据库中并不常见,因为以这种方式存储的信息通常会放在一个表中。在实际开发中,一对一关联关系可以应用于以下几方面。

(1)分割具有很多列的表。

(2)由于安全原因而隔离表的一部分。

(3)保存临时的数据,并且可以毫不费力地通过删除该表而删除这些数据。

相关推荐
曹牧7 小时前
Oracle:前缀匹配之REGEXP_LIKE
数据库·oracle
暴躁小师兄数据学院10 小时前
【AI大数据工程师特训笔记】第05讲:关联查询
数据库·sql·oracle
倔强的石头_10 小时前
《Kingbase护城河》——跨平台环境下的数据库联调实战
数据库
lzhdim10 小时前
SQL 入门 17:MySQL 数据类型:从字符串到 JSON 的全面解析
数据库·sql·mysql·json
骄马之死10 小时前
MySQL-InnoDB 核心原理
mysql
杨云龙UP10 小时前
Oracle RAC / ODA 生产环境指定 PDB 启动 SOP
linux·运维·数据库·oracle
kingwebo'sZone10 小时前
在Cent上安装Mysql 8.0的遇到的问题和解决办法
数据库·mysql·adb
幽络源小助理11 小时前
最新知识付费系统网站源码 PC+H5双端 附安装教程 – 幽络源源码网
大数据·数据库
小白考证进阶中11 小时前
Oracle OCP证书报考&考试全指南
数据库·oracle·oracle ocp·ocp认证·oracle认证·甲骨文认证·oracle ocp题库
Leon-Ning Liu12 小时前
【真实经验分享】 ORA-600 [qesmaGetTblSeg1]
数据库·oracle