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

相关推荐
tatasix29 分钟前
MySQL UPDATE语句执行链路解析
数据库·mysql
南城花随雪。42 分钟前
硬盘(HDD)与固态硬盘(SSD)详细解读
数据库
儿时可乖了43 分钟前
使用 Java 操作 SQLite 数据库
java·数据库·sqlite
懒是一种态度44 分钟前
Golang 调用 mongodb 的函数
数据库·mongodb·golang
天海华兮1 小时前
mysql 去重 补全 取出重复 变量 函数 和存储过程
数据库·mysql
gma9992 小时前
Etcd 框架
数据库·etcd
爱吃青椒不爱吃西红柿‍️2 小时前
华为ASP与CSP是什么?
服务器·前端·数据库
Yz98762 小时前
hive的存储格式
大数据·数据库·数据仓库·hive·hadoop·数据库开发
武子康2 小时前
大数据-231 离线数仓 - DWS 层、ADS 层的创建 Hive 执行脚本
java·大数据·数据仓库·hive·hadoop·mysql
黑色叉腰丶大魔王2 小时前
《MySQL 数据库备份与恢复》
mysql