簡體   English   中英

子查詢計算日期之間的天數

[英]subquery calculate days between dates

子查詢、SQL、Oracle

我是子查詢的新手,希望得到一些幫助。 我的想法是子查詢將首先運行,然后外部查詢將根據 trans_code = 'ABC' 的子查詢過濾器執行。 該查詢有效,但它從所有交易代碼中提取所有日期,trans_code 'ABC' 和 'DEF' 等。

最終目標是計算日期之間的天數。

表結構為:

acct_num    effective_date
1234        01/01/2020
1234        02/01/2020
1234        03/01/2020
1234        04/01/2021

我想執行一個查詢,如下所示:

account     Effective_Date  Effective_Date_2   Days_Diff
1234        01/01/2020      02/01/2020         31  
1234        02/01/2020      03/01/2020         29
1234        03/01/2020      04/01/2021         395
1234        04/01/2021                         0

詢問:

SELECT t3.acct_num,
       t3.trans_code,
       t3.effective_date,
       MIN (t2.effective_date) AS effective_date2,
       MIN (t2.effective_date) - t3.effective_date AS days_diff
FROM (SELECT t1.acct_num, t1.trans_code, t1.effective_date
      FROM lawd.trans t1
      WHERE t1.trans_code = 'ABC') t3
     LEFT JOIN lawd.trans t2 ON t3.acct_num = t2.acct_num
WHERE t3.acct_num = '1234' AND t2.effective_date > t3.effective_date
GROUP BY t3.acct_num, t3.effective_date, t3.trans_code
ORDER BY t3.effective_date asc

蒂亞!

使用lead()

select t.*,
       lead(effective_date) over (partition by acct_num order by effect_date) as next_efffective_date,
       (lead(effective_date) - effective_date) as diff
from lawd.trans t

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM