hivesql 求品牌打折天数

博客讲述了如何在Hive SQL中计算每个品牌总的打折销售天数,特别是处理交叉日期的情况。通过生成连续日期并去重的方法,或者利用新增字段记录最大日期并进行条件求和来解决大规模数据下的性能问题。示例数据和预期结果一并提供,展示了具体的SQL解决方案。
摘要由CSDN通过智能技术生成

需求:

计算每个品牌总的打折销售天数,注意其中的交叉日期,比如 vivo 品牌,第一次活动时间为 2021-06-05 到 2021-06-15,第二次活动时间为 2021-06-09 到 2021-06-21 其中 9 号到 15号为重复天数,只统计一次,即 vivo 总打折天数为 2021-06-05 到 2021-06-21 共计 17 天。

示例数据:

brand

s_date

end_date

oppo

2022-01-01

2022-01-08

oppo

2022-01-05

2022-01-10

vivo

2022-08-17

2022-09-01

vivo

2022-08-28

2022-09-10

apple

2022-10-01

2022-10-07

apple

2022-10-05

2022-10-15

目标结果:

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值