【问题标题】:Max(end_time) for max(date) value最大值(日期)值的最大值(结束时间)
【发布时间】:2019-08-01 12:42:42
【问题描述】:

我在 hive 数据库中有一个包含 3 列的表:

用户 日期 刷新时间

我想查询我将在第一步中获得的用户的 max(date) 和 max(refresh_time) 的 max(date)。我可以通过几个步骤(通过创建额外的表)来完成它,但是我希望有一个查询。如何正确地做到这一点?

【问题讨论】:

    标签: sql hive hiveql


    【解决方案1】:

    使用窗口函数:

    select t.*
    from (select t.*,
                 row_number() over (partition by user order by date desc, refresh_time desc) as seqnum
          from t
         ) t
    where seqnum = 1;
    

    【讨论】:

    • 哇!我从未尝试过窗口功能!工作 :) 非常感谢您的帮助!
    猜你喜欢
    • 1970-01-01
    • 2021-07-12
    • 1970-01-01
    • 1970-01-01
    • 2015-05-18
    • 2019-05-31
    • 1970-01-01
    • 2012-06-29
    • 2022-07-22
    相关资源
    最近更新 更多