SQL引导函数SQL Netezza

SQL引导函数SQL Netezza,sql,datetime,window-functions,netezza,gaps-and-islands,Sql,Datetime,Window Functions,Netezza,Gaps And Islands,我有一个表,其中只有一行id的以下示例 LINE_ID|COLLECTION_DATE |DSL_CARD_TYPE| -------|-------------------|-------------| 1234567|2020-03-25 08:46:08|ADSL_PORT | 1234567|2020-03-26 08:31:48|ADSL_PORT | 1234567|2020-03-27 08:42:40|VDSL_PORT | 1234567|2020-03

我有一个表,其中只有一行id的以下示例

LINE_ID|COLLECTION_DATE    |DSL_CARD_TYPE|
-------|-------------------|-------------|
1234567|2020-03-25 08:46:08|ADSL_PORT    |
1234567|2020-03-26 08:31:48|ADSL_PORT    |
1234567|2020-03-27 08:42:40|VDSL_PORT    |
1234567|2020-03-28 08:36:32|VDSL_PORT    |
1234567|2020-03-29 08:31:33|VDSL_PORT    |
1234567|2020-03-30 08:50:15|VDSL_PORT    |
1234567|2020-04-31 08:44:33|ADSL_PORT    |
1234567|2020-03-01 08:34:53|ADSL_PORT    |
1234567|2020-04-02 08:44:11|ADSL_PORT    |
1234567|2020-04-03 08:43:51|VDSL_PORT    |
1234567|2020-04-04 08:54:33|ADSL_PORT    |
1234567|2020-04-05 09:06:47|ADSL_PORT    |
1234567|2020-04-06 09:06:57|VDSL_PORT    |
1234567|2020-04-07 09:13:32|VDSL_PORT    |
我需要的是将DSL_卡类型分组并创建一个名为Next_COLLECTION_DATE的新列,以获取下一个DSL_卡类型并返回每个Next_组中的第一个日期,如下所示

LINE_ID|COLLECTION_DATE    |Next_COLLECTION_DATE  |DSL_CARD_TYPE|
-------|-------------------|----------------------|-------------|
1234567|2020-03-25 08:46:08|2020-03-27 08:42:40   |ADSL_PORT    |  
1234567|2020-03-27 08:42:40|2020-03-31 08:34:53   |VDSL_PORT    |
1234567|2020-03-31 08:34:53|2020-04-03 08:43:51   |ADSL_PORT    |
1234567|2020-04-03 08:43:51|2020-04-04 08:54:33   |VDSL_PORT    |   
1234567|2020-04-04 08:54:33|2020-04-06 09:06:57   |ADSL_PORT    |  
1234567|2020-04-06 09:06:57|2020-04-07 09:13:32   |VDSL_PORT    | 
我有下面的代码,它返回每个组的最后日期

select line_id, dsl_card_type, min(collection_date), max(collection_date)
from (select v.*,
             row_number() over (partition by line_id order by collection_date) as seqnum,
             row_number() over (partition by line_id, dsl_card_type order by collection_date) as seqnum_2
      from ANALYTICS.tmp.V_PORTS_LINE_CARD_DATA_ALL v
      where collection_date >= '2020-07-27 00:00:00'
     ) v
group by line_id, dsl_card_type, (seqnum - seqnum_2);```
您可以在外部查询中使用lead:

select 
    line_id, 
    dsl_card_type, 
    min(collection_date) as first_collection_date, 
    lead(min(collection_date)) over(partition by line_id order by min(collection_date)) next_collection_date
from (select v.*,
             row_number() over (partition by line_id order by collection_date) as seqnum,
             row_number() over (partition by line_id, dsl_card_type order by collection_date) as seqnum_2
      from ANALYTICS.tmp.V_PORTS_LINE_CARD_DATA_ALL v
      where collection_date >= '2020-07-27 00:00:00'
     ) v
group by line_id, dsl_card_type, (seqnum - seqnum_2)
您可以使用超前和滞后进行此操作:


瞧!不需要聚合。

非常感谢,@Gordon,它工作得非常好,我学会了一种新技术来应对这种复杂的情况。
select line_id, dsl_card_type, collection_date, 
       lead(collection_date) over (partition by line_id order by collection_date)
from (select v.*,
             lag(dsl_card_type) over (partition by line_id order by collection_date) as prev_dsl_card_type
      from ANALYTICS.tmp.V_PORTS_LINE_CARD_DATA_ALL v
      where collection_date >= '2020-07-27 00:00:00'
     ) v
where prev_dsl_card_type is null or prev_dsl_card_type <> dsl_card_type;