MySQL的 4 种连接查询

目录

[一、内连接(INNER JOIN)](#一、内连接(INNER JOIN))

[二、外连接(LEFT JOIN、RIGHT JOIN 和 FULL JOIN)](#二、外连接(LEFT JOIN、RIGHT JOIN 和 FULL JOIN))

[三、交叉连接(CROSS JOIN)](#三、交叉连接(CROSS JOIN))

四、自连接


在 MySQL 中,常见的连接查询有四种:内连接(INNER JOIN)、外连接(LEFT JOIN、RIGHT JOIN 和 FULL JOIN)、交叉连接(CROSS JOIN)和自连接。以下是对每种连接查询的详细介绍。

一、内连接(INNER JOIN)

  • 内连接是最常用的连接类型之一,它返回两个表中符合连接条件的行。如果两个表中的行没有匹配的值,则不会包含在结果集中。

  • 语法:

    SELECT * FROM table1 INNER JOIN table2 ON table1.column = table2.column;

  • 示例:

    SELECT Orders.OrderID, Customers.CustomerName
    FROM Orders
    INNER JOIN Customers ON Orders.CustomerID = Customers.CustomerID;

二、外连接(LEFT JOIN、RIGHT JOIN 和 FULL JOIN)

  • 外连接用于返回左表(左侧表)的所有行,以及与右表(右侧表)匹配的行。如果右表中没有匹配的行,则会用 NULL 值填充。

  • LEFT JOIN:返回左表的所有行以及右表中符合条件的行。

  • RIGHT JOIN:返回右表的所有行以及左表中符合条件的行。

  • FULL JOIN:返回左表和右表的所有行,如果某行在一个表中没有匹配,则用 NULL 值填充。

  • 语法:

    SELECT * FROM table1 LEFT JOIN table2 ON table1.column = table2.column;
    SELECT * FROM table1 RIGHT JOIN table2 ON table1.column = table2.column;
    SELECT * FROM table1 FULL JOIN table2 ON table1.column = table2.column;

  • 示例:

    -- LEFT JOIN
    SELECT Customers.CustomerName, Orders.OrderID
    FROM Customers
    LEFT JOIN Orders ON Customers.CustomerID = Orders.CustomerID;

    -- RIGHT JOIN
    SELECT Orders.OrderID, Customers.CustomerName
    FROM Orders
    RIGHT JOIN Customers ON Orders.CustomerID = Customers.CustomerID;

    -- FULL JOIN
    SELECT Customers.CustomerName, Orders.OrderID
    FROM Customers
    FULL JOIN Orders ON Customers.CustomerID = Orders.CustomerID;

三、交叉连接(CROSS JOIN)

  • 交叉连接返回两个表的笛卡尔积,即两个表中所有可能的组合。

  • 语法:

    SELECT * FROM table1 CROSS JOIN table2;

  • 示例:

    SELECT Customers.CustomerName, Orders.OrderID
    FROM Customers
    CROSS JOIN Orders;

四、自连接

  • 自连接是指在同一个表内进行连接操作,通常用于在表中查找相关联的信息。

  • 语法:

    SELECT a.column1, b.column2
    FROM table AS a, table AS b
    WHERE a.column = b.column;

  • 示例:

    SELECT e1.EmployeeName AS Employee, e2.EmployeeName AS Manager
    FROM Employees AS e1, Employees AS e2
    WHERE e1.ManagerID = e2.EmployeeID;

相关推荐
Java水解12 分钟前
【SQL】MySQL中空值处理COALESCE函数
后端·mysql
ss27318 分钟前
手写Spring第7弹:Spring IoC容器深度解析:XML配置的完整指南
java·前端·数据库
PFinal社区_南丞43 分钟前
PostgreSQL-10个鲜为人知的强大功能
数据库·后端
misty youth1 小时前
配置openguass 教程(自存)
数据库·ubuntu·华为·openguass
shuair2 小时前
mysql8支持远程访问 -mysql5.7支持远程访问
linux·mysql
瑞士卷@2 小时前
MyBatis入门到精通(Mybatis学习笔记)
java·数据库·后端·mybatis
白云偷星子2 小时前
MySQL笔记13
数据库·笔记·mysql
施嘉伟2 小时前
静默安装金仓数据库,到底有多简单?
数据库
Tapdata2 小时前
实时物化视图的新路径:从传统 Join 到跨源实时查询
数据库
optimistic_chen2 小时前
【Java EE进阶 --- SpringBoot】Mybatis - plus 操作数据库
数据库·spring boot·笔记·java-ee·mybatis·mybatis-plus