当前位置:网站首页 > 技术博客 > 正文

sql中的左连接

SQL LEFT JOIN 和 RIGHT JOIN 是相对的,LEFT JOIN 将返回左表(table1)中的所有记录,即使右表(table2)中没有匹配的记录也是如此。当右表中没有匹配的记录时,LEFT JOIN 仍然返回一行,只是该行的左表字段有值,而右表字段以 NULL 填充。



LEFT JOIN 以左表为主,即左表中的所有记录都会被返回,具体分为以下三种情况:

  • 如果 table1 中的某条记录在 table2 中刚好只有一条记录可以匹配,那么在返回的结果中会生成一个新的行。
  • 如果 table1 中的某条记录在 table2 中有 N 条记录可以匹配,那么在返回结果中也会生成 N 个新的行,这些行所包含的 table1 的字段值是重复的。
  • 如果 table1 中的某条记录在 table2 中没有匹配的记录,那么在返回结果中仍然会生成一个新的行,只是该行所包含的 table2 的字段值都是 NULL。

LEFT JOIN 的基本语法如下:

table1.common_column1 = table2.common_column2 是两个表的连接条件。



以上 SQL 语句将产生 table1 的全集,而 table2 中匹配的则有值,不能匹配的则以 NULL 值取代,如下图所示:



SQL LEFT JOIN

现在有如下所示的两个表,分别是客户表和订单表。



表1:CUSTOMERS 表


表2:ORDERS 表


现在,让我们使用 LEFT JOIN 连接这两个表,如下所示:

执行结果:

您可以将 LEFT JOIN 和 RIGHT JOIN 的执行结果进行对比。



如果您希望过滤掉所有 AMOUNT 为 NULL 的记录,那么可以增加 WHERE 子句,如下所示:

执行结果













  • 上一篇: JAVA 多线程
  • 下一篇: debian镜像下载
  • 版权声明


    相关文章:

  • JAVA 多线程2025-09-22 16:29:59
  • 备忘录形式是什么样的2025-09-22 16:29:59
  • 单元测试的测试流程2025-09-22 16:29:59
  • java中的四种引用类型2025-09-22 16:29:59
  • 字典树模板2025-09-22 16:29:59
  • debian镜像下载2025-09-22 16:29:59
  • l298n中文数据手册2025-09-22 16:29:59
  • 运算符重载怎么写2025-09-22 16:29:59
  • uint16范围2025-09-22 16:29:59
  • 电脑阅读软件多种格式哪个好用2025-09-22 16:29:59