Re: [SQL ] 算出每筆日期間隔

看板Database作者時間9年前 (2014/07/14 15:48), 9年前編輯推噓0(003)
留言3則, 1人參與, 最新討論串4/5 (看更多)
作者: 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
麻煩,要用where撈出來..
07/14 19:14, 2F

07/14 19:15, , 3F
然後導致IDENTITY會不連續 就很難處理.. :(
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
文章代碼(AID): #1JmujetQ (Database)
文章代碼(AID): #1JmujetQ (Database)