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

admin1年前 (2024-06-05)基础运维知识302
点击下载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 数据库设计中,选择合适的表至关重要,因为它将影响数据库的性能和可维护性。以下是选择表的指南: 1. 确定表的目的和内容 首先,明确你要创建的表的用途。考...

mysql怎么启动cmd-mysql教程

如何在 MySQL 中启动 CMD 要在 MySQL 环境中启动命令提示符 (CMD),可以按以下步骤操作: 1. 打开 MySQL 命令提示符 Windows: 在开始菜单中搜索“cmd”并打...

sql本地数据库怎么连接-SQL

SQL 本地数据库连接方法 连接到本地 SQL 数据库需要以下步骤: 第一步:选择数据库管理系统 (DBMS) 最常见的 DBMS 是 MySQL、PostgreSQL、SQL Server 和...

mysql的触发器怎么用-mysql教程

MySQL 触发器的用途 简介触发器是 MySQL 中一种数据库对象,用于在特定的事件发生时自动执行指定的操作。事件可能是表中的数据被插入、更新或删除。 使用触发器的好处 数据完整性:触发器可用...

mysql怎么修改表结构-mysql教程

MySQL 修改表结构 如何修改表结构? 要修改 MySQL 表结构,可以使用 ALTER TABLE 语句。 详细步骤: 1. 指定表名和要修改的字段 ALTER TABLE table_name...

mysql怎么启动命令-mysql教程

如何启动 MySQL 命令行 启动 MySQL 命令行有两种主要方法: 1. 使用 mysqld_safe mysqld_safe 是一个包装脚本,它启动 MySQL 服务器并处理常见错误,如端口冲...

发表评论

访客

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