⑧【MySQL】数据库查询:内连接、外连接、自连接、子查询、多表查询

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云数据库 RDS PostgreSQL,集群系列 2核4GB
简介: ⑧【MySQL】数据库查询:内连接、外连接、自连接、子查询、多表查询


⑧MySQL数据库查询


1. 多表关系

多表关系

  • 一对一 :在任意一方加入外键,关联另一方的主键,并设置外键为唯一(UNIQUE)。
  • 一对多(多对一) :在的一方建立外键,指向的一方的主键。
  • 多对多 :建立第三张表作为中间表,中间表至少包含两个外键,分别关联双方主键




2. 多表查询

多表查询

  • 在多张表中查询数据。
  • 笛卡尔积:两个集合,集合A 与 集合B中元素的所有组合情况,在多表查询时需要使用WHERE关键字JOIN ON关键字消除笛卡尔积。


🚀内连接 —— INNER JOIN

连接查询 —— 内连接

  • 内连接:
  • ①隐式内连接
SELECT 字段列表 FROM 表1,表2 WHERE 连接条件...;

  • ②显示内连接
SELECT 字段列表 FROM 表1 [INNER] JOIN 表2 ON 连接条件...;

  • == 内连接查询的是两张表交集的部分 ==


-- 演示:
-- 查询员工姓名,以及关联的部门名称(隐式内连接)
-- 表:员工表emp、部门表dept
SELECT emp.name,dept.name 
FROM emp,dept 
WHERE emp.dept_id = dept.id;
-- 查询员工姓名,以及关联的部门名称(显示内连接)
-- 表:员工表emp、部门表dept
SELECT emp.name,dept.name 
FROM emp INNER JOIN dept ON emp.dept_id = dept.id;




🚀左外连接 —— LEFT OUTER JOIN

连接查询 —— 左外连接

  • 外连接 —— 左外连接:
  • 查询表1所有数据,包含表1和表2交集部分的数据。
SELECT 字段列表 FROM 表1 LEFT [OUTER] JOIN 表2 ON 连接条件...;

-- 演示:
-- 查询emp表所有数据,以及对应部门信息(dept表数据)
-- 左外连接实现
SELECT emp.*,dept.name 
FROM emp LEFT JOIN dept 
ON emp.`dept_id` = dept.`id`;




🚀右外连接 —— RIGHT OUTER JOIN

连接查询 —— 右外连接

  • 外连接 —— 右外连接:
  • 查询表2所有数据,包含表1和表2交集部分的数据。
SELECT 字段列表 FROM 表1 RIGHT [OUTER] JOIN 表2 ON 连接条件...;


-- 演示:
-- 查询emp表所有数据,以及对应部门信息(dept表数据)
-- 右外连接实现
SELECT emp.*,dept.name 
FROM dept RIGHT JOIN emp 
ON emp.`dept_id` = dept.`id`;




🚀自连接 —— JOIN

连接查询 —— 自连接

  • 自连接:
  • ①自连接查询,可以是内连接查询,也可以是外连接查询
SELECT 字段列表 FROM 表1 别名A JOIN 表1 别名B ON 连接条件...;

-- 演示
-- 查询emp表员工 及其 所属领导的名字
-- 使用内连接
SELECT e1.`name` 员工,e2.`name` 领导
FROM emp e1 JOIN emp e2 ON e1.`managerid` = e2.`id`;
-- 查询emp表员工 及其 所属领导的名字,如果员工没有领导,也需要查询出来
-- 使用外连接
SELECT e1.`name` 员工,e2.`name` 领导
FROM emp e1 LEFT JOIN emp e2 ON e1.`managerid` = e2.`id`;




🚀联合查询 —— UNION、UNION ALL

联合查询

  • UNION查询就是把多次查询的结果合并,行程新的结果集
-- 使用UNION,对结果去重
-- 使用UNION ALL,不对结果去重
-- 要求联合的多个查询字段列表的 类型与数量 需要保持一致
SELECT 字段列表 FROM 表A ...
UNION [ALL]
SELECT 字段列表 FROM 表B ...;
-- 演示
-- 查询薪资低于5000 以及 年龄大于50的员工
-- 使用UNION,对结果去重
-- 使用UNION ALL,不对结果去重
SELECT * FROM emp WHERE emp.`salary` < 5000
UNION
SELECT * FROM emp WHERE emp.`age` > 50;




🚀子查询(嵌套查询)

子查询

  • 子查询:SQL语句中嵌套SELECT语句,称为嵌套查询,又称子查询
SELECT * FROM 表1 WHERE 字段1 = (SELECT 字段1 FROM 表2);
  • 子查询外部的语句可以是INSERT / UPDATE / DELETE / SELECT

  • 子查询分类(根据子查询结果不同):
  • 标量子查询(子查询结果为单个值)
-- 演示
-- ①标量子查询
-- 1.查询“销售部”的所有员工信息
SELECT * FROM emp 
WHERE dept_id = (SELECT id FROM dept WHERE dept.`name` = '销售部');
-- 2.查询在“方东白”之后入职的员工信息
SELECT * FROM emp 
WHERE entrydate > (SELECT entrydate FROM emp  WHERE NAME = '方东白');

  • 列子查询(子查询结果为一列)
  • 常见操作符:
  • IN:在指定的集合范围之内,多选一
  • NOT IN不在指定的集合范围之内。
  • ANY:子查询返回列表内,有任意一个满足即可
  • SOME与ANY相同,使用SOME的地方都可以使用ANY。
  • ALL:子查询返回列表的所有值都必须满足
-- 演示
-- ②列子查询
-- 1. 查询“销售部” 和 “市场部” 所有员工信息
SELECT * FROM emp
WHERE emp.`dept_id` IN(SELECT id FROM dept WHERE NAME IN('销售部','市场部'));
-- 2. 查询比财务部所有人工资都高的员工信息
SELECT * FROM emp 
WHERE emp.`salary` > 
  ALL(SELECT salary FROM emp WHERE dept_id = 
    (SELECT id FROM dept WHERE dept.`name` = '财务部'));
-- 3. 查询比财务部 任意一人 工资高的员工信息
SELECT * FROM emp 
WHERE emp.`salary` > 
  ANY(SELECT salary FROM emp WHERE dept_id = 
    (SELECT id FROM dept WHERE dept.`name` = '财务部'));

  • 行子查询(子查询结果为一行)
-- 演示
-- ③行子查询
-- 查询与“张无忌” 薪资 以及 直属领导 相同的员工信息
SELECT * FROM emp 
WHERE (salary,managerid) = 
(SELECT salary,managerid FROM emp WHERE NAME = '张无忌');

  • 表子查询(子查询结果为多行多列)
-- 演示
-- ④表子查询
-- 查询入职时间是“2006-01-01”之后入职的员工信息及其部门信息
SELECT e.*,dept.name 
FROM(SELECT * FROM emp WHERE emp.`entrydate` > '2006-01-01') e
LEFT JOIN dept ON e.dept_id = dept.`id`;





相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
打赏
0
0
0
0
4
分享
相关文章
docker拉取MySQL后数据库连接失败解决方案
通过以上方法,可以解决Docker中拉取MySQL镜像后数据库连接失败的常见问题。关键步骤包括确保容器正确启动、配置正确的环境变量、合理设置网络和权限,以及检查主机防火墙设置等。通过逐步排查,可以快速定位并解决连接问题,确保MySQL服务的正常使用。
105 82
【YashanDB知识库】YDC连接数据库报错yasdb return code is zero
【YashanDB知识库】YDC连接数据库报错yasdb return code is zero
缓存与数据库的一致性方案,Redis与Mysql一致性方案,大厂P8的终极方案(图解+秒懂+史上最全)
缓存与数据库的一致性方案,Redis与Mysql一致性方案,大厂P8的终极方案(图解+秒懂+史上最全)
从 MySQL 到时序数据库 TDengine:Zendure 如何实现高效储能数据管理?
TDengine 助力广州疆海科技有限公司高效完成储能业务的数据分析任务,轻松应对海量功率、电能及输入输出数据的实时统计与分析,并以接近 1 : 20 的数据文件压缩率大幅降低存储成本。此外,taosX 强大的 transform 功能帮助用户完成原始数据的清洗和结构优化,而其零代码迁移能力更实现了历史数据从 TDengine OSS 与 MySQL 到 TDengine 企业版的平滑迁移,全面提升了企业的数据管理效率。本文将详细解读这一实践案例。
14 0
Docker Compose V2 安装常用数据库MySQL+Mongo
以上内容涵盖了使用 Docker Compose 安装和管理 MySQL 和 MongoDB 的详细步骤,希望对您有所帮助。
194 42
MySQL生产环境迁移至YashanDB数据库深度体验
这篇文章是作者将 MySQL 生产环境迁移至 YashanDB 数据库的深度体验。介绍了 YashanDB 迁移平台 YMP 的产品相关信息、安装步骤、迁移中遇到的各种兼容问题及解决方案,最后总结了迁移体验,包括工具部署和操作特点,也指出功能有优化空间及暂不支持的部分,期待其不断优化。
如何排查和解决PHP连接数据库MYSQL失败写锁的问题
通过本文的介绍,您可以系统地了解如何排查和解决PHP连接MySQL数据库失败及写锁问题。通过检查配置、确保服务启动、调整防火墙设置和用户权限,以及识别和解决长时间运行的事务和死锁问题,可以有效地保障应用的稳定运行。
150 25
AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等