当前位置: 首页 > 知识库问答 >
问题:

Presto SQL-按所有日期/组组合展开

巩光誉
2023-03-14
date         group   subgroup value
2018-01-01   A       1        20
2018-01-04   A       1        70
2018-01-06   A       1        80
date         group   subgroup value
2018-01-01   A       1        20
2018-01-02   A       1        0
2018-01-03   A       1        0
2018-01-04   A       1        70
2018-01-05   A       1        0
2018-01-06   A       1        80

这样做的一种方法是交叉连接到一个具有日期序列的表,然后左接回到原始表,然而,我希望避免这样做,因为我有大量的组合都具有不同的最小日期和最大日期,这种类型的解决方案将相当“无效”。

共有1个答案

邬宜然
2023-03-14

如果您想为每个组/子组组合使用不同的序列,那么这就很棘手了。

但是,在PrestoDB中,您可以使用sequence()unnest(),它们几乎与generate_series()一样方便(好吧,不是真的,但它们做的是相同的事情)。

查询如下所示:

select gs.group, gs.subgroup, d.dte, coalesce(t.value, 0)
from (select group, subgroup, min(date) as mind, max(date) as maxd,
             sequence(min(date), max(date)) as date_arr
      from t
      group by group, subgroup
     ) gs cross join
     unnest(date_arr) d(dte) left join
     t
     on t.group = gs.grp and t.subgroup = gs.subgroup and t.date = d.dte
order by gs.group, gs.subgroup, d.dte;
 类似资料:
  • 问题内容: 我有一个包含时间戳名为RDD 时间 长整型: 我正在尝试按值1,值2和时间分组为YYYY-MM-DD。我尝试按演员分组(时间为日期),但随后出现以下错误: 这是否意味着无法按日期分组?我什至尝试添加另一级别的强制转换以将其作为字符串: 哪个返回相同的错误。 我已经读到我可以在RDD上使用gregationByKey,但我不明白如何在几列中使用它并将其转换为YYYY-MM-DD字符串。我

  • 感谢所有人!

  • 问题内容: 我有一个像这样的简单模型: 我想输出按月细分: 一个月内有多少笔交易() 合并值() 我不确定最好的攻击方法是什么。我已经看到了一些看上去很吓人的额外选择查询,但我的简单想法是告诉我,最好是迭代数字,从任意开始的年/月开始,一直计数到我达到当月,然后简单地抛出查询该月的过滤条件。更多数据库工作-减轻开发人员压力! 什么对你最有意义?有什么好方法可以拉回快速数据表吗?还是我的肮脏方法可能

  • 问题内容: 我在PHP数组中有一些来自XML或JSON的数据,如下所示: 我想做的是按日期订购这两项。 当排序值位于每个项目内时,是否可以按日期排序? 我需要将日期格式转换为时间戳吗? 我不想做什么 我可以使用date并将其设置为ID,但是感觉不对,因为两个项目可以具有相同的日期,因此它不是唯一的。 问题答案: 您无需在排序之前将日期转换为时间戳,但这是一个好主意,因为如果不使用它,将需要更多的时

  • 我在Oracle 11g数据库中有一个这样的表 我想知道在给定的时间段内有多少张卡进行了充值,但我希望这些信息按日期分组。如果一张卡的id已经在一个日期计算过,则不应在下一个日期计算(不同)。 这里有一些测试数据 当我像这样执行查询时,总计数为4,这是正确的。 后果 但是,当我尝试这种方法时,我的总数是10。这是因为,当我在某个日期使用“分组依据”并在ID中使用“不同”时,这种区别只适用于分组日期

  • 问题内容: 我有一个问题困扰了一段时间(头冷也无济于事!),基本上我有一个PHP数组,看起来像下面的例子: 而且我希望能够由此生成一个表格,其中包含这些表格的所有可能组合,但无需重复任何组合(无论其位置如何),因此例如 但是我希望它能够处理尽可能多的不同数组。 问题答案: 这称为“笛卡尔积”,数组http://php.net/manual/en/ref.array.php上的php手册页显示了一些