select报错 spark_SparkSQL是否支持子查询?

计划功能:

SPARK-23945(Column.isin()应该接受单列DataFrame作为输入)。

SPARK-18455(对相关子查询处理的常规支持)。

Spark 2.0+

Spark SQL应该支持相关和不相关的子查询。有关SubquerySuite详细信息,请参见。一些示例包括:

select * from l where exists (select * from r where l.a = r.c)

select * from l where not exists (select * from r where l.a = r.c)

select * from l where l.a in (select c from r)

select * from l where a not in (select c from r)

不幸的是,到目前为止(Spark 2.0)不可能使用DataFrameDSL 表达相同的逻辑。

火花<2.0

Spark在FROM子句中支持子查询(与Hive <= 0.12相同)。

SELECT col FROM (SELECT *  FROM t1 WHERE bar) t2

它根本不支持该WHERE子句中的子查询。通常来说,如果不升级到笛卡尔联接,就不能使用Spark来表示任意子查询(特别是相关子查询)。

由于子查询性能通常是典型关系系统中的重要问题,并且每个子查询都可以使用JOIN此处没有函数损失的形式表示。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值