Re: [SQL ] 算出每筆日期間隔
作者: Severine (賽非茵) 看板: Database
標題: Re: [SQL ] 算出每筆日期間隔
時間: Mon Jul 14 15:48:53 2014
=============================================================
文章修改 請pagedown到最下面
由於上篇是為了映證作法 所以找了範例資料來做~
後來實際上因為原篇推文提到的加上序號的做法 其實在我的資料不可行
所以試著把每筆資料改加上流水號的方法
SELECT row_number() OVER(ORDER BY MyDay ) AS ROWID, T1.MyDay
FROM Sheet as T1
WHERE class='1'
ORDER BY MyDay
這樣會撈出
ROWID MyDay
1 2014/01/01
2 2014/01/04
3 2014/02/06
4 2014/02/12
現在我是希望能夠針對 ROWID去做前後筆刪除 請問該如何做呢?
謝謝~
我有嘗試使用 LEFT JOIN Sheet AS T2 ON T1.ROWID = T2.ROWID +1
但是這樣當然不成功,因為原本T2並沒有ROWID的部分.想請問如何改善~?
--
※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 220.138.48.211
※ 文章網址: http://www.ptt.cc/bbs/Database/M.1405324136.A.DDA.html
※ 編輯: Severine (1.167.80.218), 07/14/2014 18:51:00
→
07/14 19:14, , 1F
07/14 19:14, 1F
→
07/14 19:14, , 2F
07/14 19:14, 2F
→
07/14 19:15, , 3F
07/14 19:15, 3F
CREATE TABLE #Dates(
MyId INT IDENTITY (1,1),
TheDate Datetime)
INSERT INTO #dates(TheDate) VALUES('1 Sep 2007 10:00')
INSERT INTO #dates(TheDate) VALUES('2 Sep 2007 12:00')
INSERT INTO #dates(TheDate) VALUES('3 Sep 2007 17:00')
INSERT INTO #dates(TheDate) VALUES('8 Sep 2007 02:00')
INSERT INTO #dates(TheDate) VALUES('10 Sep 2007 11:00')
INSERT INTO #dates(TheDate) VALUES('13 Sep 2007 13:00')
SELECT row_number() OVER(ORDER BY TheDate) as SN ,
TheDate,
(
SELECT f.TheDate
FROM #dates f
WHERE F.MyID=d.MyID-1
) as ODay,
DATEDIFF(day,
(select
f.TheDate
FROM #dates f
WHERE F.MyID=d.MyID-1)
,TheDate) Diff
FROM #dates d
嘗試這樣寫出來
會變成
流水號 新日期 前日期 差異
不過還是不知道要怎樣把Where變成用流水號row_number()去運算..
※ 編輯: Severine (1.167.80.218), 07/14/2014 19:36:27
這篇是目前做到的解法,簡單說是用view來達成
1.首先先create view,並加上row_number as SN
2.用LEFT JOIN Sheet AS T2 ON T1.SN = T2.SN +1
大致上是這樣 結束...謝謝大家 ><
===========================================================
修改後如下
雖然做出來了但是和想像中差太多..
我希望在下面的表格中,where class = 1,然後算出這兩筆差距的時間
原表格 修改一下 多一個欄位
ROW_Number MyDay Class
1 2014/01/01 1
2 2014/01/02 2
3 2014/01/03 1
4 2014/01/04 3
在RowID的方法去做DateDiff, 會每筆Row都相減 變成這樣
ROW_Number MyDay Class DateDiff
1 2014/01/01 1 1 (上下兩筆差距一天)
2 2014/01/02 2 1
3 2014/01/03 1 1
4 2014/01/04 3 1
所以目前朝向使用暫存資料表,篩選Class=1以後,加入流水號,再將暫存資料表讀出來.
並做DateDiff.不然也想不到甚麼好主意了 ><
想不到看似簡單的功能卻這麼複雜..
※ 編輯: Severine (61.219.164.156), 07/17/2014 18:30:20
討論串 (同標題文章)
Database 近期熱門文章
PTT數位生活區 即時熱門文章