【MySql】深入了解 MySQL 中的 INNER JOIN 和 OUTER JOIN


十年之前
我不认识你
你不属于我
我们还是一样
陪在一个陌生人左右
走过渐渐熟悉的街头
十年之后
我们是朋友
还可以问候
只是那种温柔
再也找不到拥抱的理由
情人最后难免沦为朋友
                     🎵 陈奕迅《十年》


在处理关系数据库时,连接(JOIN)是一种强大的工具,用于从两个或多个表中结合相关数据。MySQL 支持多种类型的连接,其中最常用的是 INNER JOIN 和 OUTER JOIN。这篇博客将详细介绍这两种连接的用法、区别以及实际应用场景。

1. INNER JOIN

定义与用法:
INNER JOIN 返回两个表中匹配的记录。如果表中有行在另一表中没有匹配,那么这些行不会出现在结果中。

基本语法:

SELECT columns
FROM table1
INNER JOIN table2
ON table1.common_field = table2.common_field;

示例场景:
假设我们有两个表,一个是员工表 Employees,一个是部门表 Departments。

Employees 表:
EmployeeID
Name
DepartmentID
Departments 表:
DepartmentID
DepartmentName

我们需要列出所有员工及其所在的部门名称,可以使用 INNER JOIN 如下:

SELECT Employees.Name, Departments.DepartmentName
FROM Employees
INNER JOIN Departments 
ON Employees.DepartmentID = Departments.DepartmentID;

这将返回所有存在于 Departments 表中 DepartmentID 的员工。

2. OUTER JOIN

定义与用法:
OUTER JOIN 返回即使在另一表中没有匹配也会返回的行。MySQL 支持三种类型的 OUTER JOIN:LEFT JOINRIGHT JOINFULL OUTER JOIN(通过联合 LEFT JOINRIGHT JOIN 实现)。

基本语法:

LEFT JOIN(返回左表的所有记录,以及右表中匹配的记录,如果没有匹配,则右表中的字段设为 NULL):

SELECT columns
FROM table1
LEFT JOIN table2
ON table1.common_field = table2.common_field;

RIGHT JOIN(返回右表的所有记录,以及左表中匹配的记录,如果没有匹配,则左表中的字段设为 NULL):

SELECT columns
FROM table1
RIGHT JOIN table2
ON table1.common_field = table2.common_field;

FULL OUTER JOIN(MySQL 不直接支持,但可以模拟):

SELECT columns
FROM table1
LEFT JOIN table2
ON table1.common_field = table2.common_field
UNION
SELECT columns
FROM table1
RIGHT JOIN table2
ON table1.common_field = table2.common_field;

示例场景:
使用同样的 Employees 和 Departments 表,如果我们想要列出所有员工及其部门名称,包括那些尚未分配部门的员工,可以使用 LEFT JOIN:

SELECT Employees.Name, Departments.DepartmentName
FROM Employees
LEFT JOIN Departments 
ON Employees.DepartmentID = Departments.DepartmentID;

这将返回所有员工,即使他们没有部门也会显示,这种情况下 DepartmentName 为 NULL。

结论

了解 INNER JOIN 和 OUTER JOIN 的区别以及适当的使用场景对于任何使用 SQL 的开发者都是必须的。通过这些连接操作,我们可以轻松地跨表查询复杂的数据,使我们能够有效地解决实际业务问题。使用正确的连接类型不仅可以确保数据的正确性,还可以提高查询效率。

相关推荐

  1. MySql深入了解 MySQL INNER JOIN OUTER JOIN

    2024-04-24 21:48:05       26 阅读
  2. MySQLCOALESCE函数:深入了解其用法与实例

    2024-04-24 21:48:05       45 阅读
  3. 深入理解MySQLMVCCUndo日志

    2024-04-24 21:48:05       185 阅读
  4. MySQL数据库备份数据深入了解

    2024-04-24 21:48:05       60 阅读
  5. 深入了解 MySQL 数值型函数

    2024-04-24 21:48:05       47 阅读
  6. msSQLMySQL区别?

    2024-04-24 21:48:05       73 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-04-24 21:48:05       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-04-24 21:48:05       101 阅读
  3. 在Django里面运行非项目文件

    2024-04-24 21:48:05       82 阅读
  4. Python语言-面向对象

    2024-04-24 21:48:05       91 阅读

热门阅读

  1. Linux笔记之more命令分页显示内容

    2024-04-24 21:48:05       25 阅读
  2. 音频格式编码

    2024-04-24 21:48:05       26 阅读
  3. KaFak知识总结(1)

    2024-04-24 21:48:05       33 阅读
  4. 每天一个数据分析题(二百七十七)

    2024-04-24 21:48:05       32 阅读
  5. python学习笔记(常用的方法)

    2024-04-24 21:48:05       36 阅读
  6. .css和.qss的区别

    2024-04-24 21:48:05       38 阅读
  7. flutter(学习日记篇-1)

    2024-04-24 21:48:05       31 阅读
  8. ABC349 A-E题解

    2024-04-24 21:48:05       38 阅读
  9. Stable Diffusion中的常用术语解析

    2024-04-24 21:48:05       26 阅读
  10. Python自动化

    2024-04-24 21:48:05       31 阅读
  11. 强化学习(五)基于时序差分法 TD 的求解

    2024-04-24 21:48:05       32 阅读
  12. 容器的通俗讲解

    2024-04-24 21:48:05       33 阅读