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、子查询

相关推荐
RainbowSea1 小时前
9-1. MySQL 性能分析工具的使用——last\_query\_cost,慢查询日志
数据库·sql·mysql
Sui_Network1 小时前
Sui 如何支持各种类型的 Web3 游戏
大数据·数据库·人工智能·游戏·web3·区块链
ZKNOW甄知科技2 小时前
IT服务运营管理体系的常用方法论与实践指南(上)
大数据·数据库·人工智能
黄雪超3 小时前
深入HBase——核心组件
数据结构·数据库·hbase
我爱松子鱼3 小时前
mysql之InnoDB Buffer Pool 深度解析与性能优化
android·mysql·性能优化
qq_529835354 小时前
Redis作为缓存和数据库的数据一致性问题
数据库·redis·缓存
知初~8 小时前
出行项目案例
hive·hadoop·redis·sql·mysql·spark·database
山猪打不过家猪9 小时前
ASP.NET Core Clean Architecture
java·数据库·asp.net
子非衣9 小时前
MySQL修改JSON格式数据示例
android·mysql·json
qwy7152292581639 小时前
13-R数据重塑
服务器·数据库·r语言