MySQL连表操作之一对多

news2025/1/16 4:49:57

MySQL连表操作之一对多

目录

  • 引入
  • 外键
    • Navicat创建外键
    • 使用外键
    • SQL命令创建外键
    • 代码删除外键
    • 代码增加外键
    • 通过外键进行数据操作

正文

回到顶部

引入

当我们在数据库中创建表的时候,有可能某些列中值内容量很大,而且重复。

例子:创建一个学生表,按学校年纪班级分,表的内容大致如下:

idnamepartment
1xxxx学校x年级x班级
2ooox学校x年级x班级
3zzzz学校x年级x班级
4dddy学校x年级x班级

我们看出来对应的partment对应的值很长,而且重复量很大,这样就很不合适。

因此我们考虑将复杂重复的部分单独拿出来分成2个表:

第一张表:

idcaption
1x学校x年级x班级
2y学校x年级x班级
3z学校x年级x班级

第二张表在之前的基础上修改的:

idnamepartment
1xxx1
2ooo2
3zzz3
4ddd1

这样看起来就很简洁了,我们将很长的且重复的部分拿出来,然后规定编号,创建学生表的时候,学生对应的partment只需要取学校对应的id便可,这样同时这2张表也就会关联起来。

说明:

1、他们的关联关系;表2中的partment和表1的id联系再一起。

2、表一的数据会对应表2中的多条数据,这就叫一对多

问题:此时,两张表是相对独立的,都可以各自插入自己的数据,这样做很合适的,并没实质行的关联?

因此,必须要将其限制。表二的partment数据必须是表一中有的,不然,就不让其增加。

这里(partment)就引入了一个名词 —- 外键

回到顶部

外键

说明:
1、外键:一个表接收另一个表的主键。
2、partment外键的是表一中的nid。
3、当我们创建了外键,则系统变默认会为我们添加,相应的约束,如:表二中的partment数据必须是表一中nid有的;表二和表一就关联起来了。

Navicat创建外键

创建part表:

1481267881120

创建person表:

1481267949167

外键的创建注意点:
创建外键时,互相对应的表中的数据类型必须一样

创建外键

1、首先在要创建外键的表上右键,选设计表。
2、进入设计表,在右边显示表行信息,然后点击外键:

1481268565436

3、选择字段,会出现一个选择框,选择你要设置外键的列;

1481268675355

4、选择参考表,选择要外键要关联的表,

1481268768575

说明:
参数数据库:因为两个数据库在同意目录下,所以这里可以不用选择;默认是同目录下的。

5、选择参考字段;选择参考表中要设为外键的列;

1481268901706

注意:
外键的创建,连个表中关联的列的数据类型必须一样,不然不能成功。

6、保存CTRL + S

使用外键

此时part中没有数据,如果此时你在person中添加数据,结果:

1481269064394

在part中添加数据,结果:

1481269148396

此时再在,person中添加数据:

1481269219718

注意:

这里不能输入part中nid没有的值,不然也会报错。

1481269304129

SQL命令创建外键

创建part:

create table part(
	nid int not null auto_increment primary key,
	caption varchar(32) not null
)

 part

创建person:

create table person(
  nid int not null auto_increment,
  name varchar(32) default null,
  email varchar(32) default null,
  part_nid int,
  primary key(nid),
  constraint fk_person_part foreign key (part_nid) references part(nid)
)

 person

创建完之后外键对应代码的关系:

image

分析:
1、从名字可以看出代码对应的是什么位置的。
2、图中名(C对应代码中的CONSTRAINT)这行可以不用设,系统会默认帮我设置,但是最好设置,如果要删除外键的时候,就可以通过这个名字进行相应的操作

代码删除外键

01

alter table person1drop foreign key fk_person1_part1;

代码增加外键

01

alter table person1add constraint fk_p1_t1foreign key (part1_nid)references part1(nid);

通过外键进行数据操作

part表:

1481274072447

person表:

1481274100625

需求:要找出person表中属于x学校的人?

1、之前学的办法:

  • 1、先去part中获取x对应的nid
  • 2、然后再通过这个nid与parson中part_id对用的关系,查找出对应的name

01

select name from personwhere part_idin (select nid form partwhere caption ="x")

2、链表方法 left join

left join

使用连表提供的方法,left join操作代码:

01

select *from personleft join parton person.part_id = part.nid

结果显示:

1481274965703

分析:
left join:相当于将part表匹配的部分直接移动到person的列后面,组合起来显示。

既然内容都合并了,那么此时我们再加上判断,就可以将要的数据获取了。

代码1:

01

select *from personleft join parton person.part_id = part.nidwhere part.caption ="x"

结果:

1481275260873

说明:

之前我们用的 * 获取的是全部的信息,如果我们获取指定的信息,可以将其修改。

如:只获取person的name代码:

01

select person.name from personleft join parton person.part_id = part.nidwhere part.caption ="x"

结果:

1481275364629

注意:
join连接的条件,使用 on 进行对接的,条件写在on后面。

01

Aleft join Bon a.xx = b.xx

left join的特点:
1、以A为主
2、将A中的所有数据罗列
3、B则只显示与A相对应的数据

问题:验证我们说的谁在前就谁为主,谁的数据就全部显示,我们将person和part换个位置?

01

select *from partleft join personon person.part_id = part.nid;

结果:

1481292040108

right join

在谁显示所有数据的上来看,他和left join刚好相反,以后面的表为主,显示其所有的数据。

inner join

会将没有建立关系的数据忽略掉。不管谁在前,结果都是一样。

01

select *from personinner join parton person.part_id = part.nid;

结果:

1481292750984

总结:
1、这几个join可以写多个的,意思就是一个表可以同时有多个外键。

2、当选择的列名,是所有表中唯一的话,可以不用写前缀的表名。如:person.part_id就可以直接写成part_id.

3、上面的part表,有个别名叫,字典表

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1413931.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

磁盘挂载过程

硬盘 - 机械 HDD----便宜---这个,企业中更多- 固态 SSD----快SSD采用电子存储介质进行数据存储和读取的一种技术,突破了传统机械硬盘的性能瓶颈, 拥有极高的存储性能,被认为是存储技术发展的新星。 与传统硬盘相比,SSD…

系统架构演变

1.1系统架构的演变 2008年以后,国内互联网行业飞速发展,我们对软件系统的需求已经不再是过去”能用就行”这种很low的档次了,像抢红包、双十一这样的活动不断逼迫我们去突破软件系统的性能上限,传统的IT企业”能用就行”的开发思…

单片机设计_智能蓝牙电子秤(51单片机、HX711AD)

想要更多项目私wo!!! 一、电路设计 智能蓝牙电子称由51单片机、HX711AD称重模块、HC-05蓝牙模块、LCD1602等电路组成硬件部分,然后上传至APP。 二、运行结果 三、部分代码 #include "main.h" #include "HX711.h" #include "uart.h" #include …

【蓝桥杯冲冲冲】[NOIP2000 提高组] 方格取数

蓝桥杯备赛 | 洛谷做题打卡day19 文章目录 蓝桥杯备赛 | 洛谷做题打卡day19[NOIP2000 提高组] 方格取数题目背景题目描述输入格式输出格式样例 #1样例输入 #1样例输出 #1 提示题解代码我的一些话 [NOIP2000 提高组] 方格取数 题目背景 NOIP 2000 提高组 T4 题目描述 设有 N N…

已解决:安卓,怎么优雅接入科大讯飞语音评测功能?

写在前面: 网上关于讯飞接入的博客都很少,按说讯飞都是业界翘楚,不知为何,很少搜索到精品,一搜就是一个要求开会员的博客,我也是醉了。讯飞提供的文档也是不清晰,我是摸着石头过河,…

MySQL JSON数据类型全解析(JSON datatype and functions)

JSON(JavaScript Object Notation)是一种常见的信息交换格式,其简单易读且非常适合程序处理。MySQL从5.7版本开始支持JSON数据类型,本文对MySQL中JSON数据类型的使用进行一个总结。 目录 一、MySQL中的JSON 1.1 JSON数据格式 1.2 …

最长公共子串的问题(正常方法和矩阵法,动态规划)

题目: 给定两个字符串 text1 和 text2,返回这两个字符串的最长 公共子序列 的长度。如果不存在 公共子序列 ,返回 0 。 一个字符串的 子序列 是指这样一个新的字符串:它是由原字符串在不改变字符的相对顺序的情况下删除某些字符…

Windows Qt C++ VTK 绘制三维曲线

Qt 自带数据可视化从文档上看,只能实现三维曲面。 QwtPlot3D在Qt6.6.0上没编译通过。 QCustomPlot 只能搞二维。 VTK~搞起。抄官网demo。 后续需求: 1、对数轴 2、Y轴逆序 3、Z轴值给色带,类似等高线图的色带 期待各位大佬多多指导。…

如何快速搭建实用的爬虫管理平台

目录 一、前言 二、选择合适的爬虫框架 三、搭建数据库 步骤1 步骤2 步骤3 四、搭建Web服务器 步骤1 步骤2 步骤3 步骤4 五、管理爬虫 六、总结 一、前言 爬虫是互联网数据采集的关键工具,但是随着数据量的增加和需求的多样化,手动运行和管…

超越传统,想修哪里就修哪里,SUPIR如何通过文本提示实现智能图像修复

项目简介 通过参数增加使得模型不仅能够修复图像中的错误或损坏,还能根据文本提示进行智能修复。例如根据描述来改变图像中的特定细节。这样的处理方式提升了图像修复的质量和智能度,使得模型能够更准确、更灵活地恢复和改进图像。 SUPIR的主要功能图像…

详解矩阵的LDU分解

目录 一. 矩阵分解 二. 解方程 三. 例题说明 四. 矩阵的LDU分解 五. 矩阵三角分解的唯一性 一. 矩阵分解 其实我们可以把一个线性系统(Linear System)看成两个三角系统(Triangular Systems),本文章将解释为什么可…

QT实现USB摄像头接入显示

一、UVC协议简介 UVC全称是USB Video Class(USB视频类),是一种标准化的USB视频设备通信协议,它定义了摄像头与主机之间的数据传输协议和格式。 UVC协议的出现,解决了摄像头厂商之间互不兼容,以及摄像头应…

2.Linux的例行性工 作(计划任务)

目录 1. 场景: 2. 单一执行的例行性任务--at(一次性) 2.1. 安装 2.2. at命令详解 2.2.1. 格式 2.2.2. 参数 2.2.3. 时间格式 2.2.4. 实验1 2.2.5. 实验2 2.2.6. 注意 2.2.7. at命令执行过程分析 2.2.8. 实验3 3. 循环执行的例行…

Elasticsearch:聊天机器人、人工智能和人力资源:电信公司和企业组织的成功组合

作者:来自 Elastic Jrgen Obermann, Piotr Kobziakowski 让我们来谈谈大型企业人力资源领域中一些很酷且改变游戏规则的东西:生成式 AI 和 Elastic Stack 的绝佳组合。 现在,想象一下大型电信公司的典型人力资源部门 — 他们正在处理一百万件…

mac/macos上编译electron源码

官方教程:Build Instructions | Electron 准备工作这里不写了,参考官方文档,还有上一篇windows编译electron electron源码下载及编译-CSDN博客 差不多步骤,直接来 网络记得使用魔法 下载编译步骤 0. 选择目录很重要&#xff0…

Emergent Abilities of Large Language Models 机翻mark

摘要 证明通过扩大语言模型可以可靠地提高性能和样本效率在广泛的下游任务。相反,本文讨论了我们称之为大型语言模型的新兴能力的一种不可预测的现象。我们认为如果一个能力不存在于较小的模型中,但在较大的模型中存在,则该能力就是新兴的。…

InforSuiteAS中创中间件windows环境部署

版本:InforSuiteAS_StE_V10.0.5.2.1 环境要求:Java环境 DK1.8版本, 内存2GB或以上 , 硬盘空间 10GB或以上, 监视器 图形界面安装需要256色以上,字符界面安装没有色彩要求 ,浏览器 Microsoft …

el-tree基础的树形节点设置节点不能选中高亮出来,对已经选中的节点设置disabled,对当前节点刚选中后设置禁用disabled

一、 el-tree基础的树形节点设置节点不能选中高亮出来 需求 我们使用element-ui或者element-plus的时候会遇到树形控件的使用,我们使用树形控件会限制有的节点不让选中和高亮出来,这个时候需要我们做限制。在实现中我们发现了element-ui和element-plus…

SQL注入实战:绕过操作

一:绕过操作 1、常用绕过方式 大小写绕过: 通过修改关键字内字母大小写来绕过过滤措施。例如:AnD11Select* from ** oRdEr by 1 双写绕过: 使用双写绕过。因为在过滤过程中只进行了一次替换。就是将关键字替换为对应的空。 比如 union在…

使用Opencv-python库读取图像、本地视频和摄像头实时数据

使用Opencv-python库读取图像、本地视频和摄像头实时数据 Python中使用OpenCV读取图像、本地视频和摄像头数据很简单, 首先需要安装Python,然后安装Opencv-python库 pip install opencv-python然后在PyCharm或者VScode等IDE中输入对应的Python代码 一…