SQL极简核心:JOIN

本文详细解析了INNERJOIN、LEFTJOIN的基本概念,比较了ON与WHERE的区别,并通过经典题目展示了JOIN在实际应用中的技巧。重点讲解了JOIN操作的本质——行过滤与列合并,以及在LEFTJOIN中对左表和右表的不同处理。

JOIN ON 的本质是行过滤 + 列合并

  • JOIN 的本质就是列合并
  • ON 的本质是行过滤,一般使用两个表格的连接字段(外键/连接键)相等作为条件(目前Hive 中只支持等值连接)

(该篇仅介绍最常用的 INNER JOINLEFT JOIN

1. INNER JOIN

在这里插入图片描述

不论如何,JOIN ON 的本质是行过滤 + 列合并

INNER JOIN 与 与一般的JOIN通用,其区别是两张表并非完全相同,又要求交集的情况下使用INNER JOIN

具体原理:

SELECT xxx
FROM t_a
JOIN t_b
ON t_a.col1 = t_b.col2
WHERE condition

拿上面代码举例,使用ON将满足t_a表col1字段t_b表col2字段相等的行全部筛选出来(行过滤)进行列合并。(前者默认两张表有不同的部分)

划重点:I

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值