首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >从餐桌上记录第二天和第二天的计数

从餐桌上记录第二天和第二天的计数
EN

Stack Overflow用户
提问于 2017-03-06 00:33:00
回答 1查看 101关注 0票数 0

我正在尝试使用下面的单元查询来查找第一天+1的记录计数。因为我们有hive 0.10版本,所以出错。

代码语言:javascript
复制
select 
lead(count(*)) over (order by day),
day 
from device_fact_kpis 
where day=20160301 group 
by day;

失败: ParseException第1行:27缺少at‘(“近”)(在子查询源中,第1行:28)无法识别子查询源中“day”附近的输入

是否有一种方法可以在第二天找到计数,而不必使用铅函数,因为0.10没有铅函数。

EN

回答 1

Stack Overflow用户

发布于 2017-03-06 00:39:37

您的查询无论如何都不能工作,因为您需要在白天进行筛选之前执行lead()

无论如何,您可以使用CTE和join

代码语言:javascript
复制
with t as (
      select day, count(*) as cnt
      from table t
      group by day
     )
select day, cnt, tnext.cnt as next_cnt
from t left join
     t tnext
     on tnext.day = date_add(t.day, 1);

编辑:

没有CTE的版本非常类似:

代码语言:javascript
复制
select day, cnt, tnext.cnt as next_cnt
from (select day, count(*) as cnt
      from table t
      group by day
     ) t left join
     (select day, count(*) as cnt
      from table t
      group by day
     ) tnext
     on tnext.day = date_add(t.day, 1);
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/42615816

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档