MySQL 联合查询的使用教程

 更新时间:2025年04月27日 09:59:06   作者:2401_89793006  
联合查询(JOIN)通过将两个或更多表根据一定条件连接起来,从而形成一个虚拟的结果集,本文将详细介绍 MySQL 联合查询的使用,帮助你掌握不同类型的联接及其应用场景,感兴趣的朋友一起看看吧

MySQL 联合查询教程

在 MySQL 中,联合查询用于从多个表中检索数据,常用于关联表中的信息。联合查询(JOIN)通过将两个或更多表根据一定条件连接起来,从而形成一个虚拟的结果集。MySQL 支持多种类型的联合查询,包括 INNER JOINLEFT JOINRIGHT JOINFULL OUTER JOIN 等。

本文将详细介绍 MySQL 联合查询的使用,帮助你掌握不同类型的联接及其应用场景。

一、基本的联合查询

1.1 INNER JOIN(内连接)

INNER JOIN 是最常见的一种连接方式,它返回的是两个表中匹配的记录。如果某一表中的行没有与另一表中的行匹配,则这行数据不会出现在结果集中。

语法:

SELECT column_names
FROM table1
INNER JOIN table2
ON table1.column_name = table2.column_name;

示例:

假设有两个表 employees(员工表)和 departments(部门表):

employees 表:

idnamedepartment_id
1Alice1
2Bob2
3Charlie1

departments 表:

idname
1HR
2IT

查询 employeesdepartments 表中的匹配记录,返回员工名称和所属部门名称:

SELECT employees.name AS employee_name, departments.name AS department_name
FROM employees
INNER JOIN departments
ON employees.department_id = departments.id;

结果:

employee_namedepartment_name
AliceHR
BobIT
CharlieHR

1.2 LEFT JOIN(左连接)

LEFT JOIN 返回左表的所有记录,以及右表中匹配的记录。如果右表没有匹配的记录,则返回 NULL

语法:

SELECT column_names
FROM table1
LEFT JOIN table2
ON table1.column_name = table2.column_name;

示例:

SELECT employees.name AS employee_name, departments.name AS department_name
FROM employees
LEFT JOIN departments
ON employees.department_id = departments.id;

结果:

employee_namedepartment_name
AliceHR
BobIT
CharlieHR

假设我们在 employees 表中增加了一个没有对应部门的员工:

INSERT INTO employees (name, department_id) VALUES ('David', NULL);

查询结果会是:

employee_namedepartment_name
AliceHR
BobIT
CharlieHR
DavidNULL

1.3 RIGHT JOIN(右连接)

RIGHT JOIN 返回右表的所有记录,以及左表中匹配的记录。如果左表没有匹配的记录,则返回 NULL

语法:

SELECT column_names
FROM table1
RIGHT JOIN table2
ON table1.column_name = table2.column_name;

示例:

SELECT employees.name AS employee_name, departments.name AS department_name
FROM employees
RIGHT JOIN departments
ON employees.department_id = departments.id;

结果:

employee_namedepartment_name
AliceHR
BobIT
CharlieHR

如果 departments 表中增加了一个没有员工的部门:

INSERT INTO departments (id, name) VALUES (3, 'Finance');

查询结果会是:

employee_namedepartment_name
AliceHR
BobIT
CharlieHR
NULLFinance

1.4 FULL OUTER JOIN(全连接)

FULL OUTER JOIN 返回左表和右表中的所有记录。如果某一表中的行没有与另一表中的行匹配,则返回 NULL。MySQL 本身不直接支持 FULL OUTER JOIN,但可以通过 UNION 来模拟。

语法:

SELECT column_names
FROM table1
LEFT JOIN table2
ON table1.column_name = table2.column_name
UNION
SELECT column_names
FROM table1
RIGHT JOIN table2
ON table1.column_name = table2.column_name;

示例:

SELECT employees.name AS employee_name, departments.name AS department_name
FROM employees
LEFT JOIN departments
ON employees.department_id = departments.id
UNION
SELECT employees.name AS employee_name, departments.name AS department_name
FROM employees
RIGHT JOIN departments
ON employees.department_id = departments.id;

结果:

employee_namedepartment_name
AliceHR
BobIT
CharlieHR
DavidNULL
NULLFinance

二、基于多个条件的联合查询

2.1 使用多个条件进行连接

可以在 ON 子句中使用多个条件进行联合查询,多个条件之间使用 ANDOR 进行连接。

示例:

SELECT employees.name AS employee_name, departments.name AS department_name
FROM employees
INNER JOIN departments
ON employees.department_id = departments.id
AND employees.age > 25;

该查询返回部门中年龄大于 25 岁的员工名称。

2.2 使用 USING 关键字

如果两个表中有相同的列名,可以使用 USING 来简化查询语句。USING 关键字自动将相同的列名作为连接条件。

示例:

SELECT employees.name AS employee_name, departments.name AS department_name
FROM employees
INNER JOIN departments
USING (department_id);

三、联合查询中的排序与限制

3.1 排序查询结果

可以在联合查询中使用 ORDER BY 来对结果进行排序。排序可以基于一个或多个列进行。

示例:

SELECT employees.name AS employee_name, departments.name AS department_name
FROM employees
INNER JOIN departments
ON employees.department_id = departments.id
ORDER BY employees.name;

3.2 限制查询结果

可以使用 LIMIT 语句限制联合查询返回的记录数。

示例:

SELECT employees.name AS employee_name, departments.name AS department_name
FROM employees
INNER JOIN departments
ON employees.department_id = departments.id
LIMIT 5;

四、总结

本文介绍了 MySQL 中常用的联合查询类型,包括:

  • INNER JOIN:返回两个表中匹配的记录。
  • LEFT JOIN:返回左表的所有记录以及右表中匹配的记录。
  • RIGHT JOIN:返回右表的所有记录以及左表中匹配的记录。
  • FULL OUTER JOIN:返回两个表中的所有记录,使用 UNION 模拟。
  • 多个条件连接:可以使用 ANDOR 等多个条件进行连接查询。

掌握这些联合查询的使用方法,能够帮助你更加灵活地操作 MySQL 数据库,获取需要的结果。如果你希望深入了解更多内容,可以参考 MySQL 官方文档。

到此这篇关于MySQL 联合查询教程的文章就介绍到这了,更多相关mysql 联合查询内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 分享MySQL常用 内核 Debug 几种常见方法

    分享MySQL常用 内核 Debug 几种常见方法

    这篇文章主要给大家分享的是MySQL常用的内核Debug技巧,掌握 MySQL 内核源码的阅读和调试能力,不仅是数据库研发人员的日常,也是 DBA 进阶的必经之路,下面一起进入文章了解更多相关内容吧
    2022-03-03
  • Mysql主从延时图解方法

    Mysql主从延时图解方法

    我们知道,一个服务器开放N个链接给客户端连接的,就会有大并发的更新操作,但是从服务器的里面读取binlog线程得仅有一个,当某个SQL在从服务器上执行的时间稍长 或由某个SQL要锁表就会导致主服务器的SQL大量积压,未被同步到从服务器,就导致了主从不一致,也就是主从延迟
    2022-01-01
  • 图文介绍mysql中:=和=的区别

    图文介绍mysql中:=和=的区别

    这篇文章主要给大家介绍了关于mysql中:=和=区别的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用mysql具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-08-08
  • MySQL删除表的三种方式(小结)

    MySQL删除表的三种方式(小结)

    这篇文章主要介绍了MySQL删除表的三种方式(小结),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-09-09
  • MySQL数据库迁移全过程

    MySQL数据库迁移全过程

    本文详细解析了MySQL数据库迁移的整个过程,包括准备工作、迁移方法、注意事项和优缺点,文章介绍了三种常见的迁移方法:使用mysqldump导出和导入、使用ibd文件迁移和使用目录整体迁移,每种方法都有其优缺点,选择合适的方法取决于具体的迁移需求和环境
    2025-02-02
  • MySQL的几种安装方式及配置问题小结

    MySQL的几种安装方式及配置问题小结

    这篇文章主要介绍了MySQL的几种安装方式及配置,然后在文章底部给大家介绍了安装过程中的问题总结,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2017-07-07
  • MySQL存储毫秒数据的方法

    MySQL存储毫秒数据的方法

    MySQL中没有可以直接存储毫秒数据的数据类型,但是不过MySQL却能识别时间中的毫秒部分。这篇文章主要介绍了MySQL存储毫秒数据的方法,需要的朋友可以参考下
    2014-06-06
  • Mysql数据库性能优化二

    Mysql数据库性能优化二

    这篇文章主要介绍了Mysql数据库性能优化二 的相关资料,需要的朋友可以参考下
    2016-04-04
  • Mybatis特殊字符处理的详解

    Mybatis特殊字符处理的详解

    这篇文章主要介绍了Mybatis特殊字符处理的详解的相关资料,需要的朋友可以参考下
    2017-07-07
  • Mysql8.4.3LTS中离线部署的实现示例

    Mysql8.4.3LTS中离线部署的实现示例

    本文详细介绍了在Ubuntu 24.04系统上离线部署MySQL 8.4.3 LTS,包括环境配置、安装步骤等步骤,对小白有一定的帮助,感兴趣的可以了解一下
    2024-11-11

最新评论