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

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: ⑧【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`;





相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
18天前
|
SQL 关系型数据库 MySQL
12 PHP配置数据库MySQL
路老师分享了PHP操作MySQL数据库的方法,包括安装并连接MySQL服务器、选择数据库、执行SQL语句(如插入、更新、删除和查询),以及将结果集返回到数组。通过具体示例代码,详细介绍了每一步的操作流程,帮助读者快速入门PHP与MySQL的交互。
32 1
|
20天前
|
SQL 关系型数据库 MySQL
go语言数据库中mysql驱动安装
【11月更文挑战第2天】
35 4
|
26天前
|
存储 缓存 固态存储
怎么让数据库查询更快
【10月更文挑战第28天】
30 2
|
28天前
|
存储 缓存 关系型数据库
怎么让数据库查询更快
【10月更文挑战第25天】通过以上综合的方法,可以有效地提高数据库查询的速度,提升应用程序的性能和响应速度。但在优化过程中,需要根据具体的数据库系统、应用场景和数据特点进行合理的调整和测试,以找到最适合的优化方案。
|
27天前
|
监控 关系型数据库 MySQL
数据库优化:MySQL索引策略与查询性能调优实战
【10月更文挑战第27天】本文深入探讨了MySQL的索引策略和查询性能调优技巧。通过介绍B-Tree索引、哈希索引和全文索引等不同类型,以及如何创建和维护索引,结合实战案例分析查询执行计划,帮助读者掌握提升查询性能的方法。定期优化索引和调整查询语句是提高数据库性能的关键。
150 1
|
29天前
|
存储 关系型数据库 MySQL
查询服务器CPU、内存、磁盘、网络IO、队列、数据库占用空间等等信息
查询服务器CPU、内存、磁盘、网络IO、队列、数据库占用空间等等信息
246 2
|
15天前
|
运维 关系型数据库 MySQL
安装MySQL8数据库
本文介绍了MySQL的不同版本及其特点,并详细描述了如何通过Yum源安装MySQL 8.4社区版,包括配置Yum源、安装MySQL、启动服务、设置开机自启动、修改root用户密码以及设置远程登录等步骤。最后还提供了测试连接的方法。适用于初学者和运维人员。
123 0
|
28天前
|
监控 关系型数据库 MySQL
数据库优化:MySQL索引策略与查询性能调优实战
【10月更文挑战第26天】数据库作为现代应用系统的核心组件,其性能优化至关重要。本文主要探讨MySQL的索引策略与查询性能调优。通过合理创建索引(如B-Tree、复合索引)和优化查询语句(如使用EXPLAIN、优化分页查询),可以显著提升数据库的响应速度和稳定性。实践中还需定期审查慢查询日志,持续优化性能。
63 0
|
2月前
|
存储 关系型数据库 MySQL
Mysql(4)—数据库索引
数据库索引是用于提高数据检索效率的数据结构,类似于书籍中的索引。它允许用户快速找到数据,而无需扫描整个表。MySQL中的索引可以显著提升查询速度,使数据库操作更加高效。索引的发展经历了从无索引、简单索引到B-树、哈希索引、位图索引、全文索引等多个阶段。
64 3
Mysql(4)—数据库索引
|
29天前
|
关系型数据库 MySQL Linux
在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,包括准备工作、下载源码、编译安装、配置 MySQL 服务、登录设置等。
本文介绍了在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,包括准备工作、下载源码、编译安装、配置 MySQL 服务、登录设置等。同时,文章还对比了编译源码安装与使用 RPM 包安装的优缺点,帮助读者根据需求选择最合适的方法。通过具体案例,展示了编译源码安装的灵活性和定制性。
85 2