编程技术文章分享与教程

网站首页 > 技术文章 正文

数据库连表join顺口溜加详解(数据库表连接的几种方式的区别)

hmc789 2024-11-16 20:53:16 技术文章 1 ℃


左连接,左表全,右表缺NULL;
右连接,右表全,左表缺NULL。

内连接,找交集,匹配才显示;
外连接,求并集,不匹配补NULL。

LEFT 左表全带,RIGHT 右表全带,
FULL 两边都带,NULL 补空白。

JOIN 之前 ON 筛,WHERE 后再筛选。

数据库的 JOIN 操作是用于将两个或多个表中的行组合起来,基于这些表之间的某些列之间的关联条件。JOIN 是 SQL 语言中的一个重要部分,它允许用户从多个表中检索数据,并将这些数据组合成一个结果集。

INNER JOIN(内连接)

  • 返回两个表中满足关联条件的匹配行。
  • 如果某行在一个表中没有匹配,则不会出现在结果中。

示例:

SELECT A.*, B.*  
FROM tableA A  
INNER JOIN tableB B ON A.key = B.key;

LEFT JOIN(左连接)或 LEFT OUTER JOIN

  • 返回左表中的所有行,以及右表中满足关联条件的匹配行。
  • 如果右表没有匹配行,则结果为 NULL
  • 示例:
SELECT A.*, B.*  
FROM tableA A  
LEFT JOIN tableB B ON A.key = B.key;

RIGHT JOIN(右连接)或 RIGHT OUTER JOIN

  • 返回右表中的所有行,以及左表中满足关联条件的匹配行。
  • 如果左表没有匹配行,则结果为 NULL
  • 示例:
SELECT A.*, B.*  
FROM tableA A  
RIGHT JOIN tableB B ON A.key = B.key;

FULL JOIN(全连接)或 FULL OUTER JOIN

  • 返回两个表中满足关联条件的匹配行,以及任何一方没有匹配行的结果为 NULL。
  • 示例:
SELECT A.*, B.*  
FROM tableA A  
FULL JOIN tableB B ON A.key = B.key;

注意事项

  • 当使用 JOIN 时,应确保连接条件是正确的,以避免得到错误的结果。
  • 在处理大数据集时,JOIN 操作可能会很消耗资源,因此需要考虑查询的性能优化。
  • 使用索引可以加速 JOIN 操作,特别是当连接条件涉及到的列被索引时。

Tags:

标签列表
最新留言