• 【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;
    
    • 1
    • 2
    • 3
    • 4

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

    Employees 表:
    EmployeeID
    Name
    DepartmentID
    Departments 表:
    DepartmentID
    DepartmentName
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

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

    SELECT Employees.Name, Departments.DepartmentName
    FROM Employees
    INNER JOIN Departments 
    ON Employees.DepartmentID = Departments.DepartmentID;
    
    • 1
    • 2
    • 3
    • 4

    这将返回所有存在于 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;
    
    • 1
    • 2
    • 3
    • 4

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

    SELECT columns
    FROM table1
    RIGHT JOIN table2
    ON table1.common_field = table2.common_field;
    
    • 1
    • 2
    • 3
    • 4

    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;
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9

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

    SELECT Employees.Name, Departments.DepartmentName
    FROM Employees
    LEFT JOIN Departments 
    ON Employees.DepartmentID = Departments.DepartmentID;
    
    • 1
    • 2
    • 3
    • 4

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

    结论

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

  • 相关阅读:
    数据集资源之一:最经典大规模、多样化的自动驾驶视频数据集——BDD100K数据集
    树形DP()
    R语言有关模型方面的函数(model.)介绍-model.matrix
    My Forty-Third Page - 二叉搜索树中的插入操作 - By Nicolas
    如何学习VBA_3.2.18:DIR函数的补充说明
    Git
    javascript正则表达式-模式和修饰符,字符类,词边界\b,转义特殊字符Unicode修饰符u和类\p{..}字符串开始和结尾,
    HTML学习总结
    java04 -程序控制结构
    【python入门小知识】实现人名全大写,全小写,首字母大写
  • 原文地址:https://blog.csdn.net/qq_35240081/article/details/138015770