设为首页 加入收藏

TOP

hive中的left semi join替换sql中的in操作
2014-11-24 03:33:59 来源: 作者: 【 】 浏览:5
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

评论

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

·Linux Shell脚本教程 (2025-12-26 17:51:10)
·Qt教程,Qt5编程入门 (2025-12-26 17:51:07)
·MongoDB安装教程(Li (2025-12-26 17:51:04)
·bios设置按什么选择 (2025-12-26 17:20:08)
·知乎 - 知乎 (2025-12-26 17:20:04)