【发布时间】:2018-11-01 19:29:59
【问题描述】:
我有一个如下所示的数据框:
ID DATE
ABC 2018-02-07
ABC 2018-02-10
ABC 2018-02-13
ABC 2018-02-22
ABC 2018-02-26
ABC 2018-02-28
ABC 2018-04-06
ABC 2018-04-06
ABC 2018-04-12
我正在尝试添加 3 个附加列:(1) 所有记录的最早日期 (2) 日期和最早日期之间的时间 (3) 返回记录的第 n 次出现 #,返回重复日期的第 n 条记录的最大值。我期待以下输出:
PEL_ID TRANSACTIONDATEDIFF EARLIESTEXPOSURE TIMEDIFF NTH_FREQUENCY
ABC 2018-02-07 2018-02-07 0 1
ABC 2018-02-10 2018-02-07 3 2
ABC 2018-02-13 2018-02-07 6 3
ABC 2018-02-22 2018-02-07 15 4
ABC 2018-02-26 2018-02-07 19 5
ABC 2018-02-28 2018-02-07 21 6
ABC 2018-04-06 2018-02-07 58 8
ABC 2018-04-12 2018-02-07 64 9
这是我的 SQL 代码:
SELECT
PEL_ID,TRANSACTIONDATEDIFF,EARLIESTEXPOSURE,TIME_DIFF,MAX(NTH_FREQUENCY)
FROM (
SELECT C.*,ROW_NUMBER() OVER(PARTITION BY PEL_ID ORDER BY PEL_ID) AS
NTH_FREQUENCY FROM
(SELECT A.PEL_ID,A.TRANSACTIONDATEDIFF,B.EARLIESTEXPOSURE,
(A.TRANSACTIONDATEDIFF-B.EARLIESTEXPOSURE) AS TIME_DIFF FROM
CAMP_31323_TODATE A JOIN (SELECT PEL_ID,MIN(TRANSACTIONDATEDIFF) AS
EARLIESTEXPOSURE FROM CAMP_31323_TODATE
GROUP BY PEL_ID) B ON A.PEL_ID=B.PEL_ID
ORDER BY A.PEL_ID) C
)
GROUP BY PEL_ID,TRANSACTIONDATEDIFF,EARLIESTEXPOSURE,TIME_DIFF
ORDER BY PEL_ID,TRANSACTIONDATEDIFF ASC;
除了 nth_frequency 之外,大部分代码都在工作,这是输出:
PEL_ID TRANSACTIONDATEDIFF EARLIESTEXPOSURE TIMEDIFF NTH_FREQUENCY
ABC 2018-02-07 2018-02-07 0 3
ABC 2018-02-10 2018-02-07 3 6
ABC 2018-02-13 2018-02-07 6 8
ABC 2018-02-22 2018-02-07 15 2
ABC 2018-02-26 2018-02-07 19 7
ABC 2018-02-28 2018-02-07 21 1
ABC 2018-04-06 2018-02-07 58 5
ABC 2018-04-12 2018-02-07 64 9
我不确定为什么会这样。任何帮助将不胜感激。提前致谢。
【问题讨论】:
标签: sql oracle window-functions