mysql多表查询

1、 笛卡尔积与隐式内连接

对select * fom emp,dept;所返回的结果集遵循笛卡尔积运算;

为了消除冗余的笛卡尔积;我们需要使用where x 例如

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

其实这是一种隐式内连接。

2、 多表查询分类

我们可以将多表查询分成: 内连接,外连接,自连接等。

3、 内连接的两种写法

内连接有隐式内连接和显示内连接

隐式内连接FROM 表1, 表2 WHERE 条件,写法简洁,但在表较多时可读性稍差。

显式内连接FROM 表1 INNER JOIN 表2 ON 条件,使用 INNER JOIN 关键字,逻辑更清晰,推荐在复杂查询中使用。

4、 外连接的实战经验

对于外连接,我们可以分为左外连接和右外连接

实际上在实际开发,我们只focus on左外就可以了(右外也可调成左外嘛)

使用的语法是:

from 表1 left join 表2 on 条件

结果和表1的数据量是一样的,例如表1有n条数据,左外连接的结果就有n条数据

**即左外连接(LEFT JOIN)保证左表的所有数据都被返回,右表没有匹配的则用 NULL 填充,这在业务中最常用,**比如 "查询所有员工及其所属部门,包括没有部门的员工"。

5、 自连接

它将同一张表通过别名的方式当作两张不同的表来使用,从而实现对表中数据的关联查询。

1、必须使用表别名 因为是同一张表进行连接,必须用别名(如 a 和 b)来区分 "两张表",否则数据库无法识别你要引用的是哪一部分的数据。

2、既可以是内连接,也可以是外连接

3、例子:

1)需求:查询员工及其直属领导的名字(只查询有领导的员工)

SELECT a.name, b.name FROM emp a, emp b WHERE a.managerid = b.id;

这是一个隐式内连接,只会返回那些有领导(即 managerid 不为空)的员工。

2)需求:查询所有员工及其领导的名字,包括没有领导的员工

SELECT a.name '员工', b.name '领导' FROM emp a LEFT JOIN emp b ON a.managerid = b.id; 因为要忙组左表的数据全都被返回,所以使用左外连接。

左表是员工表,右表是领导表。 如果某个员工没有领导(managerid 为 NULL),那么 b.name 这一列就会显示为 NULL。

联合查询

一、联合查询是一种将多个 SELECT 查询的结果集纵向合并成一个大结果集的查询方式,它的核心作用是实现 "多表同构数据的合并展示"。

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

2、列名由第一个查询决定 最终结果集的列名,由第一个 SELECT 语句中的字段名决定,后续查询的列名会被忽略。

二、UNION vs UNION ALL

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

正因为union要去重,需要额外的排序和比较,性能较低 适用于当你需要确保结果集中没有重复数据时。

2、例子:

假设我们有两张结构相同的表:emp_2024(2024 年员工)和 emp_2025(2025 年员工)。|

sql 复制代码
SELECT name, salary FROM emp_2024
UNION ALL
SELECT name, salary FROM emp_2025;
相关推荐
KaMeidebaby1 天前
卡梅德生物技术快报|抗独特型抗体开发:半抗原检测技术瓶颈拆解,抗独特型抗体开发工程化实践
前端·数据库·人工智能·其他·百度·新浪微博
NiceCloud喜云1 天前
Claude Files API 深入:从上传、复用到配额管理的工程化指南
android·java·数据库·人工智能·python·json·飞书
A XMan.1 天前
域名Whois信息查询V2版API接入指南
数据库
heimeiyingwang1 天前
【架构实战】可观测性体系:从监控到全链路追踪
网络·数据库·架构
网管NO.11 天前
SQL 日期函数全套精讲!时间格式化、日期加减、年月日提取,做日报周报直接套用
数据库·sql
杨云龙UP1 天前
Linux 根分区被日志吃满?一次 58G Broker 日志清理实战_2026-05-20
linux·运维·服务器·数据库·hdfs·apache
sdk大全1 天前
Studio 3T for MongoDB 2025.13.0
数据库·mongodb
码农阿豪1 天前
平替MongoDB:金仓多模数据库助力电子证照国产化实践
数据库·mongodb
罗超驿1 天前
22.深入剖析JDBC架构:从原生API到企业级数据交互核心
java·数据库·mysql·面试
易辰君1 天前
【数据库】MongoDB深度解析与Python操作指南:从安装到实战操作全覆盖
数据库·mongodb