Mysql数据库 7.SQL语言 关联关系

关联关系介绍

Mysql是一个关系型数据库,不仅可以存储数据,还可以维护数据与数据之间的关系------通过在数据表中添加字段建立约束

数据与数据之间的关联关系:

1.一对一关联

2.一对多关联

3.多对一关联

4.多对多关联

一个表的外键对应另一个表的主键的关系叫做关联关系

为了建立一个表与另一个表的关系,产生关联关系,由外键对应主键,建立两表之间的关联关系

1.一对一关联

一对一关联方案:

方案一:将两表中主键相同的数据相互对应(几乎使用不到)

方案二:在任意一表中添加唯一外键添加一字段,与另一表的主键进行关联,要求添加的外键字段中添加的值必须在其关联表的主键中存在

一对一时候一个数据只能对应另一个表中的一个数据,不能重复,所以需要加上unique约束

2.一对多与多对一关联

方案:外键约束------在多的一段添加外键,与另一端的主键进行关联,将一对多中一的表的字段设置成多的表的副键,与多的一表的主键进行关联

一对多和多对一时,一个数据可能对应另一个表的多个数据,所以不用加上unique约束

一对一、多对一、一对多情况时,建立外键与另一个表进行关联

3.多对多关联

方法:额外创建一张关系表来维护多对多关联------在关系表中定义两个外键,分别与两个数据表的主键进行关联

一旦涉及到多对多关联的情况,一定会涉及到第三张表,由前两张表的主键进行联合主键作为主键

用两个表的主键联合主键作为第三张新表的主键存在,建立新表

可以将关系表进行关联作为一个新表记录新的数据存在

相关推荐
爱吃土豆的马铃薯ㅤㅤㅤㅤㅤㅤㅤㅤㅤ24 分钟前
dbeaver导入数据及配置讲解
数据库·dbeaver
NineData1 小时前
NineData 新增支持 AWS ElastiCache 复制链路
数据库
雨笋情缘1 小时前
【2025年8月5日】mysql-8.0.38-linux-glibc2.12-x86_64.tar.xz 安装MySQL操作指引
linux·数据库·mysql
士心凡2 小时前
MySQL
数据库·mysql
draymond71073 小时前
MSQL-聚簇索引与非聚簇索引的比较
数据库·mysql
数据库那些事儿3 小时前
阿里云DMS Data Copilot——高效智能的数据助手,助力企业实现数据驱动的未来
运维·数据库·agent
~央千澈~3 小时前
MongoDB 从3.4.0升级到4.0.0完整指南实战-优雅草蜻蜓I即时通讯水银版成功升级-卓伊凡|bigniu
数据库·postgresql
小沈熬夜秃头中୧⍤⃝4 小时前
Python 基础语法(二):流程控制语句详解
开发语言·数据库·python
不辉放弃4 小时前
pyspark中的kafka的读和写案例操作
大数据·数据库·pyspark·大数据开发
祢真伟大4 小时前
DM8达梦数据库错误码信息汇编-8.1.4.80 20250430-272000-20149 Pack1
数据库