→ Severine:現在覺得真是當初資料表沒有設計好 把東西雜在一起才這麼 07/14 19:14
→ Severine:麻煩,要用where撈出來.. 07/14 19:14
→ Severine:然後導致IDENTITY會不連續 就很難處理.. :( 07/14 19:15
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