mysql中内连接,左连接和右连接的区别-mysql教程

admin2年前 (2024-06-05)基础运维知识393
点击下载TXT

MySQL 中内连接、左连接和右连接的区别

内连接 (INNER JOIN)

  • 只返回两个表中具有匹配行的记录。
  • 匹配失败的记录将被丢弃。

左连接 (LEFT JOIN)

  • 返回左表中的所有记录,即使右表中没有匹配的行。
  • 右表中没有匹配行的记录将用 NULL 值填充。

右连接 (RIGHT JOIN)

  • 返回右表中的所有记录,即使左表中没有匹配的行。
  • 左表中没有匹配行的记录将用 NULL 值填充。

用法

  • 内连接:用于查找两个表之间具有匹配行的记录,并丢弃不匹配的记录。
  • 左连接:用于查找左表的所有记录,并包含右表中匹配行的记录。
  • 右连接:用于查找右表的所有记录,并包含左表中匹配行的记录。

语法

  • 内连接:

    SELECT *
    FROM table1
    INNER JOIN table2
    ON table1.column1 = table2.column2;
    登录后复制
  • 左连接:

    SELECT *
    FROM table1
    LEFT JOIN table2
    ON table1.column1 = table2.column2;
    登录后复制
  • 右连接:

    SELECT *
    FROM table1
    RIGHT JOIN table2
    ON table1.column1 = table2.column2;
    登录后复制

例子

假设我们有以下两个表:

Table1:
| id | name |
|---|---|
| 1 | John |
| 2 | Mary |
| 3 | Bob |

Table2:
| id | address |
|---|---|
| 1 | 123 Main St |
| 2 | 456 Elm St |
| 4 | 789 Oak St |
登录后复制
  • 内连接:

    SELECT *
    FROM Table1
    INNER JOIN Table2
    ON Table1.id = Table2.id;
    登录后复制

    结果:

id name address
1 John 123 Main St
2 Mary 456 Elm St
  • 左连接:

    SELECT *
    FROM Table1
    LEFT JOIN Table2
    ON Table1.id = Table2.id;
    登录后复制

    结果:

id name address
1 John 123 Main St
2 Mary 456 Elm St
3 Bob NULL
  • 右连接:

    SELECT *
    FROM Table1
    RIGHT JOIN Table2
    ON Table1.id = Table2.id;
    登录后复制

    结果:

id name address
1 John 123 Main St
2 Mary 456 Elm St
4 NULL 789 Oak St

相关文章

mysql授权怎么用-mysql教程

MySQL 授权指南 授权是什么? 授权是指授予其他用户访问和操作 MySQL 数据库的权限。 如何授权? 使用 MySQL 的 GRANT 语句可以授予授权。语法如下: GRANT ON TO...

mysql是什么有什么用-mysql教程

什么是 MySQL? MySQL 是一个开源关系数据库管理系统(RDBMS),用于存储和管理数据。它是一种广泛用于 Web 应用程序、电子商务和数据仓储等各种领域的流行数据库。 MySQL 的用途...

mysql怎么停止服务-mysql教程

如何在 MySQL 中停止服务 要停止 MySQL 服务,请按照以下步骤操作: 方法 1:使用 MySQL 命令行客户端 打开命令行终端。 连接到 MySQL 服务器: <a style=...

mysql怎么导入mdf文件-mysql教程

如何将 MDF 文件导入 MySQL MySQL 无法直接导入 Microsoft SQL Server (MSSQL) 的 MDF 文件。但是,可以通过以下步骤将 MDF 文件中的数据迁移到 My...

mysql分组排序怎么查-mysql教程

MySQL 分组排序查询方法 在 MySQL 中,可以通过使用 GROUP BY 和 ORDER BY 子句对结果集进行分组和排序。 分组 GROUP BY 子句将行按指定的列或表达式分组,并将每个...

mysql去重怎么去-mysql教程

MySQL 中如何去重 在 MySQL 中进行数据去重,有多种方法可以实现。 1. 使用 DISTINCT 关键字 DISTINCT 关键字用于消除查询结果中的重复行,仅保留不重复的数据。使用方式如...

发表评论

访客

◎欢迎参与讨论,请在这里发表您的看法和观点。