设为首页 加入收藏

TOP

hive中的left semi join替换sql中的in操作
2014-11-24 03:33:59 来源: 作者: 【 】 浏览:4
Tags:hive left semi join 替换 sql 操作
hive中的left semi join替换sql中的in操作
LEFT SEMI JOIN 是 IN/EXISTS 子查询的一种更高效的实现。
www.2cto.com
Hive 当前没有实现 IN/EXISTS 子查询,所以你可以用 LEFT SEMI JOIN 重写你的子查询语句。
LEFT SEMI JOIN 的限制是, JOIN 子句中右边的表只能在
ON 子句中设置过滤条件,在 WHERE 子句、SELECT 子句或其他地方过滤都不行。
SELECT a.key, a.value
FROM a
WHERE a.key in
(SELECT b.key
FROM B);
可以被重写为:www.2cto.com
SELECT a.key, a.val
FROM a LEFT SEMI JOIN b on (a.key = b.key)
】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到: 
上一篇hive的join操作 下一篇逻辑Standby之failover

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容:

·数据库:推荐几款 Re (2025-12-25 12:17:11)
·如何最简单、通俗地 (2025-12-25 12:17:09)
·什么是Redis?为什么 (2025-12-25 12:17:06)
·对于一个想入坑Linux (2025-12-25 11:49:07)
·Linux 怎么读? (2025-12-25 11:49:04)