首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >配置单元SQL:选择事件前的所有行

配置单元SQL:选择事件前的所有行
EN

Stack Overflow用户
提问于 2018-08-07 01:05:22
回答 1查看 91关注 0票数 0

在Hive中,我有以下数据

代码语言:javascript
运行
复制
sess,person,type,number
a   mary    I   1
a   mary    I   2
a   mary    V   3
a   mary    V   4
b   mary    I   1
b   mary    V   2
b   mary    C   3
a   john    I   1
a   john    I   2
a   john    V   3
a   john    V   4
b   john    I   1
b   john    V   2
b   john    C   3

如何为第一个type=V之前的每个人和会话选择所有内容?输出应如下所示

代码语言:javascript
运行
复制
sess,person,type,number
    a   mary    I   1
    a   mary    I   2
    a   mary    V   3
    b   mary    I   1
    b   mary    V   2
    a   john    I   1
    a   john    I   2
    a   john    V   3
    b   john    I   1
    b   john    V   2
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-08-07 01:20:17

您可以使用窗口函数:

代码语言:javascript
运行
复制
select t.*
from (select t.*,
             min(case when type = 'V' then number end) over (partition by session, person order by number) as min_aid
      from t
     ) t
where min_aid is null or number <= aid;
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/51712519

复制
相关文章

相似问题

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