MySQL—多表查询(概述、基本实操、分类)

一、引言

概述:指的是从多张表中查询数据。

二、实操

打开 DataGrip 进行尝试多表查询。

(1)表结构的准备以及数据的插入

分别是:员工表 emp 以及 部门表。员工表中字段 dept_id 是外键,关联部门表的主键 id。

emp:员工表(增加了17条记录)

补充:set null ,当父表主键删除字段值,对应子表外键字段值变成 null 。

部门表:dept (6条记录)
(2)多表查询
sql 复制代码
SELECT * FROM emp,dept;

出现这样的问题,就需要我们解决。下面介绍笛卡儿积的相关知识。

(3)笛卡儿积

概述:笛卡尔乘积是指在数学中,两个集合:A集合和B集合的所有组合情况。

(在多表查询时,需要消除无效的笛卡尔积)

例如:

所以刚刚我们查询的两张表:emp、dept ,就是它们所有的组合情况(17*6=102条)。

根据我们的需求,我们需要的是以下这种查询结果就可以了:(需要把无效的笛卡尔积消除掉)

(4)解决方法:

我们要通过它们两张表,所关联的字段去解决这个问题。

所以让表 emp 的字段 dept_id等于 表 dept 的字段 id (dept_id = dept.id)就可以了。

sql 复制代码
SELECT * FROM emp,dept WHERE(emp.dept_id = dept.id) ORDER BY emp.id;

这就是我们所介绍和学习的多表查询。

三、多表查询的分类

多表查询的分类主要分为两类。

1、连接查询(分为内连接、外连接以及自连接)

内连接:

相当于查询A、B交集部分数据

外连接:

左外连接:查询左表所有数据,以及两张表交集部分数据

右外连接:查询右表所有数据,以及两张表交集部分数据

自连接:

指的是当前只有一张表。当前表与自身的连接查询,自连接必须使用表别名(后面会提到)
2、子查询

相关推荐
啦啦啦_9999几秒前
Redis-0-业务逻辑
数据库·redis·缓存
自不量力的A同学32 分钟前
Redisson 4.2.0 发布,官方推荐的 Redis 客户端
数据库·redis·缓存
Exquisite.34 分钟前
Mysql
数据库·mysql
全栈前端老曹1 小时前
【MongoDB】深入研究副本集与高可用性——Replica Set 架构、故障转移、读写分离
前端·javascript·数据库·mongodb·架构·nosql·副本集
R1nG8631 小时前
CANN资源泄漏检测工具源码深度解读 实战设备内存泄漏排查
数据库·算法·cann
阿钱真强道1 小时前
12 JetLinks MQTT直连设备事件上报实战(继电器场景)
linux·服务器·网络·数据库·网络协议
逍遥德2 小时前
Sring事务详解之02.如何使用编程式事务?
java·服务器·数据库·后端·sql·spring
笨蛋不要掉眼泪2 小时前
Redis哨兵机制全解析:原理、配置与实战故障转移演示
java·数据库·redis·缓存·bootstrap
Coder_Boy_2 小时前
基于SpringAI的在线考试系统-整体架构优化设计方案
java·数据库·人工智能·spring boot·架构·ddd
fen_fen10 小时前
Oracle建表语句示例
数据库·oracle