微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

基于列从SQL的一行中生成多行

如何解决基于列从SQL的一行中生成多行

我有一个包含以下五列的表格:

enter image description here

ID是此处的PI。 BEGIN_WINDOWEND_WINDOWTIMESTAMP列。 DURATION_DAYS_RUP的计算方法是将DURATION_HRS除以24并四舍五入。

我想做的是基于DURATION_DAYS_RUP,我需要创建多行。

  • 如果该值为1,则创建的行就是具有相同ID BEGIN_WINDOWEND_WINDOW的同一行。
  • 如果大于1,例如。如图2所示,将创建两行-一行ID相同,BEGIN_WINDOW是原始行的值,而END_WINDOW是24小时+ BEGIN_WINDOW第二行将是相同的IDBEGIN_WINDOW是第一行的END_WINDOW,而END_WINow是此行的BEGIN_WINDOW + 24小时。

请参见以下示例:

enter image description here

我进行了很多研究,但似乎找不到执行此操作的窍门。如果有人有想法,将不胜感激!

解决方法

您可以使用Teradata的EXPAND ON syntax

SELECT x.ID,BEGIN(pd) as BEGIN_WINDOW,BEGIN(pd) + INTERVAL '24' HOUR as END_WINDOW
FROM mytable x
EXPAND ON PERIOD(x.BEGIN_WINDOW,x.END_WINDOW) AS pd
BY INTERVAL '24' HOUR;
,

您可以使用递归查询:

with recursive cte (id,begin_window,end_window,duration_days_rup) as (
    select 
        id,case when duration_days_rup = 1 then end_window else begin_window + interval '1' day end,duration_days_rup - 1
    from mytable 
    union all
    select 
        id,begin_window + interval '1' day,case when duration_days_rup = 1 then end_window else end_window + interval '1' day end,duration_days_rup - 1
    from cte
    where duration_days_rup > 0
)
select id,end from cte

查看您的查询,我怀疑您是否确实需要duray_days_rup列,它是派生信息。我们可以使用直接日期比较。我认为您想要的逻辑是:

with recursive cte (id,real_end_window) as (
    select 
        id,least(end_window,begin_window + interval '1' day),end_window
    from mytable 
    union all
    select 
        id,least(real_end_window,end_window + interval '1' day),real_end_window
    from cte
    where begin_window + interval '1' day > real_end_window
)
select id,end from cte

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。