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

本文涉及的产品
云数据库 RDS MySQL,集群版 2核4GB 100GB
推荐场景:
搭建个人博客
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
目录
相关文章
|
16小时前
|
JavaScript 关系型数据库 API
Nest.js 实战 (二):如何使用 Prisma 和连接 PostgreSQL 数据库
这篇文章介绍了什么是Prisma以及如何在Node.js和TypeScript后端应用中使用它。Prisma是一个开源的下一代ORM,包含PrismaClient、PrismaMigrate、PrismaStudio等部分。文章详细叙述了安装PrismaCLI和依赖包、初始化Prisma、连接数据库、定义Prisma模型、创建Prisma模块的过程,并对比了Prisma和Sequelize在Nest.js中的使用体验,认为Prisma更加便捷高效,没有繁琐的配置。
Nest.js 实战 (二):如何使用 Prisma 和连接 PostgreSQL 数据库
|
6天前
|
SQL Java 关系型数据库
Java面试题:描述JDBC的工作原理,包括连接数据库、执行SQL语句等步骤。
Java面试题:描述JDBC的工作原理,包括连接数据库、执行SQL语句等步骤。
15 0
|
6天前
|
ARouter 关系型数据库 MySQL
Django项目同时连接多个不同的数据库(7)
【7月更文挑战第7天】在Django项目中配置连接多个数据库,你需要: 1. 在`settings.py`中配置多个数据库, 2. 在`settings.py`内设置数据库路由,指定每个应用使用的数据库,
22 2
|
7天前
|
SQL 数据库 Python
Django框架数据库ORM查询操作(6)
【7月更文挑战第6天】```markdown Django ORM常用数据库操作:1) 查询所有数据2) 根据ID查询 3) 精确查询 4) 分页排序
15 1
|
10天前
|
SQL 存储 数据库
MSSQL数据库性能调优实战:索引、查询与并发控制的深度剖析
在数据库管理领域,Microsoft SQL Server(MSSQL)的性能调优是保障业务高效运行的核心任务
|
7天前
|
关系型数据库 数据库 RDS
利用DTS将自建mysql5.7版本数据库迁移至对应rds报错
利用DTS将自建mysql5.7版本数据库迁移至对应rds报错
30 0
|
8天前
|
关系型数据库 MySQL 网络安全
Mysql 数据库主从复制
在MySQL主从复制环境中,配置了两台虚拟机:主VM拥有IP1,从VM有IP2。主VM的`my.cnf`设置server-id为1,启用二进制日志;从VM设置server-id为2,开启GTID模式。通过`find`命令查找配置文件,编辑`my.cnf`,在主服务器上创建复制用户,记录二进制日志信息,然后锁定表并备份数据。备份文件通过SCP传输到从服务器,恢复数据并配置复制源,启动复制。检查复制状态确认运行正常。最后解锁表,完成主从同步,新用户在从库中自动更新。
970 6
Mysql 数据库主从复制
|
8天前
|
缓存 运维 关系型数据库
数据库容灾 | MySQL MGR与阿里云PolarDB-X Paxos的深度对比
经过深入的技术剖析与性能对比,PolarDB-X DN凭借其自研的X-Paxos协议和一系列优化设计,在性能、正确性、可用性及资源开销等方面展现出对MySQL MGR的多项优势,但MGR在MySQL生态体系内也占据重要地位,但需要考虑备库宕机抖动、跨机房容灾性能波动、稳定性等各种情况,因此如果想用好MGR,必须配备专业的技术和运维团队的支持。 在面对大规模、高并发、高可用性需求时,PolarDB-X存储引擎以其独特的技术优势和优异的性能表现,相比于MGR在开箱即用的场景下,PolarDB-X基于DN的集中式(标准版)在功能和性能都做到了很好的平衡,成为了极具竞争力的数据库解决方案。
|
10天前
|
存储 关系型数据库 MySQL
探索MySQL:关系型数据库的基石
MySQL,作为全球最流行的开源关系型数据库管理系统(RDBMS)之一,广泛应用于各种Web应用、企业级应用和数据仓库中
|
11天前
|
XML 关系型数据库 MySQL
支付系统----微信支付19---集成MyBatis-plus,数据库驱动对应的依赖版本设置问题,5没版本没有cj这个依赖,mysql驱动默认的是版本8,这里是一个父类,数据库都有,写个父类,继承就行
支付系统----微信支付19---集成MyBatis-plus,数据库驱动对应的依赖版本设置问题,5没版本没有cj这个依赖,mysql驱动默认的是版本8,这里是一个父类,数据库都有,写个父类,继承就行