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;

相关推荐
江湖人称小鱼哥1 小时前
Prisma 命令安全指南
数据库·安全·prisma
Gauss松鼠会1 小时前
【openGauss】1分钟掌握:openGauss活动会话CPU占用率获取
数据库·database·opengauss
豆沙沙包?1 小时前
2025年--Lc182--sql(排序和分组)--Java版
java·数据库·sql
CryptoRzz2 小时前
欧美(美股、加拿大股票、墨西哥股票)股票数据接口文档
java·服务器·开发语言·数据库·区块链
APItesterCris2 小时前
构建弹性数据管道:利用淘宝商品 API 进行流式数据采集与处理
linux·数据库·windows
九河云2 小时前
TOS + 数字孪生:集装箱码头的智能进化密码
大数据·服务器·网络·数据库·数字化转型
手握风云-3 小时前
MySQL数据库精研之旅第十九期:存储过程,数据处理的全能工具箱(二)
数据库·mysql
孟意昶3 小时前
Doris专题17- 数据导入-文件格式
大数据·数据库·分布式·sql·doris
你可以永远相信功夫熊猫3 小时前
金蝶云·星瀚 | 生产制造成本核算终极实操手册(从0到1,含两套完整案例)
数据库·erp
Thepatterraining3 小时前
MySQL零基础教程:DDL/DCL/DML详解,从建库到存储过程一篇搞定!
数据库·sql·mysql