MySQL基础篇 - 多表查询

01 多表关系

【1】概念:项目开发中,在进行数据库表结构设计时,会根据业务需求及业务模块之间的关系,分析并设计表结构,由于业务之间相互关联,所以各表结构之间也存在着各种联系,基本上分为三种:一对多(多对一),多对多(要建立中间表),一对一。

02 多表查询概述

【1】概念:多表查询就是指在多张表中查询数据

【2】如果直接查询有多表关系的表:

例如:select * from emp , dept; 则查询出来的结果将是两张表的笛卡尔积个数据。

但其实我们只需要一些数据,则此时我们可以通过外键关系在where里面写上条件即可(消除无效笛卡尔积)

例如:select * from emp , dept where emp.dept_id = dept.id;

【3】多表查询的分类:

03 内连接

【1】内连接:查询两个表有外键关联的数据,如果子表中某个外键数据没有与父表主键关联的值则不会被查出来。

【2】分类:

① 隐式内连接:select 字段列表 from 表1 as 别名,表2 as 别名 where 外键关系;

② 显示内连接:select 字段列表 from 表1 as 别名 inner join 表2 as 别名 on 外键关系;

【说明】:在多表查询时,我们通常会给表取别名,注意:一旦我们给表取别名后不能再直接使用表名了。

04 外连接

【1】左外连接:查询表1的数据,以及表1和表2交集部分的数据。

【2】右外连接:查询表2的数据,以及表1和表2交集部分的数据。

【3】分类:外连接:如果子表中某个外键数据没有与父表主键关联的值也会被查出来。

① 左外连接:select 字段列表 form 表1 as 别名 left outer join 表2 as 别名 on 外键关系;

② 右外连接:select 字段列表 form 表1 as 别名 right outer join 表2 as 别名 on 外键关系;

【4】说明:下图案例中很好的说明了:

内连接:如果子表中某个外键数据没有与父表主键关联的值则不会被查出来。

外连接:如果子表中某个外键数据没有与父表主键关联的值也会被查出来。

05 自连接

【1】场景:表中的外键关联的是自己所在表的某个字段,例如:查询某个员工的领导,而领导也是员工。

【2】语法:其实就是利用取别名,把一张表看成两张表,可以内查询也可以外查询。

① 内连接(隐式写法):select 字段列表 form 表一 别名,表一 别名 where 外键关系;

② 外连接(左外连接):select 字段列表 from 表一 别名 left outer join 表一 别名 on 外键关系;

06 联合查询

【1】概念:union查询,就是把多次查询的结果合并起来,形成一个新的查询结果集。

【2】注意:

① 对于联合查询的多张表的列数必须保持一致,字段类型也需要保持一致。

(比如查多张成绩单上满足某条件的数据,然后把它合并起来形成一张表)

② union all会将全部的数据直接合并在一起,union会对合并之后的数据去重。

【3】语法:

select 字段列表 from 表a ...

union all/union

select 字段列表 from 表b ...

07 子查询

【1】概念:SQL语句中嵌套select语句,称为嵌套查询,即子查询。

【2】子查询外部的语句可以是insert/update/delete/select的任何一个,select会用得多一些。

【3】举例:select * from t1 where column1 = (select column1 from t2)

【4】分类:根据子查询的结果分为:

① 标量子查询(子查询结果为单个值)

② 列子查询(子查询结果为一列)

③ 行子查询(子查询结果为一行)

④ 表子查询(子查询结果为多行多列)

【5】根据子查询位置,分为:where之后,form之后,select之后。

07_01 标量子查询

【1】标量子查询:子查询返回的查询结果是单个值(数字,字符串,日期等)

【2】标量子查询中常用的操作符:=,<>,>,>=,<,<=

07_02 列子查询

【1】列子查询:子查询的结果是一列(可以是多行)

【2】列子查询中常用的操作符:in,not in,any,some,all

【3】in是只要满足其中的一种,any是只要=,<>,>,>=,<,<= 其中一种

07_03 行子查询

【1】行子查询:返回的结果是一行(可以是多列)

【2】行子查询中常用的操作符:=,<>,in,not in

【3】注意:a = 12 && b = 13 可以写成 (a, b)= (12, 13),因此下图示例中的写法才是那样。

07_04 表子查询

【1】表子查询:返回的结果是多行多列的。

【2】表子查询常用的操作符:in

相关推荐
姚远Oracle ACE1 小时前
解读Oracle AWR报告:Global Cache and Enqueue Services - Workload Characteristics
数据库·oracle
流星白龙1 小时前
【Qt】7.信号和槽_connect函数用法(2)
java·数据库·qt
Zzz 小生3 小时前
Claude Code学习笔记(四)-助你快速搭建首个Python项目
大数据·数据库·elasticsearch
nongcunqq7 小时前
abap 操作 excel
java·数据库·excel
rain bye bye7 小时前
calibre LVS 跑不起来 就将setup 的LVS Option connect下的 connect all nets by name 打开。
服务器·数据库·lvs
冻咸鱼8 小时前
MySQL的配置
mysql·配置
阿里云大数据AI技术9 小时前
云栖实录|MaxCompute全新升级:AI时代的原生数据仓库
大数据·数据库·云原生
不剪发的Tony老师9 小时前
Valentina Studio:一款跨平台的数据库管理工具
数据库·sql
weixin_3077791310 小时前
在 Microsoft Azure 上部署 ClickHouse 数据仓库:托管服务与自行部署的全面指南
开发语言·数据库·数据仓库·云计算·azure
六元七角八分10 小时前
pom.xml
xml·数据库