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 分钟前
数据库-联合查询(内连接外连接),子查询,合并查询
java·数据库·sql·mysql
从零开始学习人工智能29 分钟前
Doris 数据库深度解析:架构、原理与实战应用
数据库·架构
LiRuiJie1 小时前
深入剖析MySQL锁机制,多事务并发场景锁竞争
数据库·mysql
2501_915374351 小时前
Faiss向量数据库全面解析:从原理到实战
数据库·faiss
睡觉待开机1 小时前
0. MySQL在Centos 7环境安装
数据库·mysql·centos
2501_915374351 小时前
Faiss vs Milvus 深度对比:向量数据库技术选型指南
数据库·milvus·faiss
一叶知秋哈2 小时前
Java应用Flink CDC监听MySQL数据变动内容输出到控制台
java·mysql·flink
傻啦嘿哟2 小时前
Python 数据分析与可视化实战:从数据清洗到图表呈现
大数据·数据库·人工智能
cookqq3 小时前
mongodb源码分析session异步接受asyncSourceMessage()客户端流变Message对象
数据库·sql·mongodb·nosql
呼拉拉呼拉3 小时前
Redis故障转移
数据库·redis·缓存·高可用架构