[英]How do I get entries in the next month from oracle sql?
假設我有一個包含“ user_id,日期,分數”的表,每個用戶每個月都有一個分數,但並非總是在同一天。
我想查詢一個具有“ user_id,date,score_delta”的查詢,其中score_delta是“ date”和下個月之間分數的變化? 我是否需要像to_date(to_char(date,...?
這是一種方法(留給讀者練習的余量商):
CREATE TABLE scores (user_id VARCHAR2(32), test_date DATE, score NUMBER);
INSERT INTO scores VALUES('U1',SYSDATE-61, 85);
INSERT INTO scores VALUES('U1',SYSDATE-31, 89);
INSERT INTO scores VALUES('U1',SYSDATE, 92);
INSERT INTO scores VALUES('U2',SYSDATE-61, 65);
INSERT INTO scores VALUES('U2',SYSDATE-31, 89);
INSERT INTO scores VALUES('U2',SYSDATE, 84);
COMMIT;
SELECT s1.user_id, s1.test_date, s2.score-s1.score delta
FROM scores s1
JOIN (SELECT user_id, trunc(test_date,'MM') test_date, score FROM scores) s2
ON (s1.user_id = s2.user_id AND
trunc(add_months(s1.test_date,1),'MM') = s2.test_date);
USER_ID TEST_DATE DELTA
-------------------------------- --------- ----------
U1 9/15/2009 3
U1 8/16/2009 4
U2 9/18/2009 -5
U2 8/19/2009 24
編輯 :今天下午很慢,所以我決定研究10g提供的這種分析功能(進一步將自己拖入當前世紀;-),並使用LAG函數重寫以上內容:
SELECT user_id, test_date, score
, LAG(score, 1, NULL) OVER (PARTITION BY user_id ORDER BY test_date DESC) - score delta
, LAG(score, 1, NULL) OVER (PARTITION BY user_id ORDER BY test_date DESC) AS next_score
FROM scores
ORDER BY 1, 2 DESC;
產生:
USER_ID TEST_DATE SCORE DELTA NEXT_SCORE
-------------------------------- ----------- ---------- ---------- ----------
U1 10/19/2009 92
U1 9/18/2009 89 3 92
U1 8/19/2009 85 4 89
U2 10/19/2009 84
U2 9/18/2009 89 -5 84
U2 8/19/2009 65 24 89
媽你看 沒有自我加入! 現在,它很漂亮;-)(順便說一句,解釋計划表明自連接效率不高)。
作為跳板,我從這個asktom.com問題開始。
這樣的事情應該返回下個月輸入的user_id,日期和分數。
select user_id, date, score from table where
date between ((select sysdate from dual)
and (select add_months(sysdate, 1) FROM dual));
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.