我使用的是SQL Server 2008 R2和我有以下數據集:T-SQL來創建一個ID列
+---------+--------------+--------------+----------+------------+------------+
| Dossier | refmouvement | refadmission | refunite | datedeb | datefin |
+---------+--------------+--------------+----------+------------+------------+
| P0| 2567 | 1234 | 227 | 2012-01-01 | 2012-01-02 |
| P0| 2568 | 1234 | 227 | 2012-01-02 | 2012-01-03 |
| P0| 2569 | 1234 | 224 | 2012-01-03 | 2012-01-06 |
| P0| 2570 | 1234 | 232 | 2012-01-06 | 2012-01-10 |
| P0| 2571 | 1234 | 232 | 2012-01-10 | 2012-01-15 |
| P0| 2572 | 1234 | 232 | 2012-01-15 | 2012-01-20 |
| P0| 2573 | 1234 | 232 | 2012-01-20 | 2012-01-25 |
| P0| 2574 | 1234 | 224 | 2012-01-25 | 2012-01-29 |
| P0| 2575 | 1234 | 227 | 2012-01-29 | 2012-02-05 |
| P0| 2576 | 1234 | 227 | 2012-02-05 | 2012-02-10 |
| P0| 2577 | 1234 | 232 | 2012-02-10 | 2012-02-15 |
| P0| 2578 | 1234 | 201 | 2012-02-15 | 2012-02-26 |
+---------+--------------+--------------+----------+------------+------------+
該數據集由datedeb
下令,否則稱爲startdate
。
正如你可以看到這是一個連續的數據集,其中datefin
等於下一行的datedeb
我需要創建一個ID
列將會給基礎上,refunite
一個唯一的ID和datedeb
列狀這樣的:
+----+---------+--------------+--------------+----------+------------+------------+
| ID | Dossier | refmouvement | refadmission | refunite | datedeb | datefin |
+----+---------+--------------+--------------+----------+------------+------------+
| 1 | P0| 2567 | 1234 | 227 | 2012-01-01 | 2012-01-02 |
| 1 | P0| 2568 | 1234 | 227 | 2012-01-02 | 2012-01-03 |
| 2 | P0| 2569 | 1234 | 224 | 2012-01-03 | 2012-01-06 |
| 3 | P0| 2570 | 1234 | 232 | 2012-01-06 | 2012-01-10 |
| 3 | P0| 2571 | 1234 | 232 | 2012-01-10 | 2012-01-15 |
| 3 | P0| 2572 | 1234 | 232 | 2012-01-15 | 2012-01-20 |
| 3 | P0| 2573 | 1234 | 232 | 2012-01-20 | 2012-01-25 |
| 4 | P0| 2574 | 1234 | 224 | 2012-01-25 | 2012-01-29 |
| 5 | P0| 2575 | 1234 | 227 | 2012-01-29 | 2012-02-05 |
| 5 | P0| 2576 | 1234 | 227 | 2012-02-05 | 2012-02-10 |
| 6 | P0| 2577 | 1234 | 232 | 2012-02-10 | 2012-02-15 |
| 7 | P0| 2578 | 1234 | 201 | 2012-02-15 | 2012-02-26 |
+----+---------+--------------+--------------+----------+------------+------------+
我只是不能換我的頭周圍RANK()
,ROW_NUMBER()
或DENSE_RANK()
功能或一個組合可以實現這一點,我已經到處找,但I C ANNOT發現了什麼,也許我沒有使用正確的關鍵字,但我無法弄清楚
任何幫助將不勝感激
感謝。
下面是我試過到目前爲止代碼:
SELECT
ROW_NUMBER() over(order by t1.[datedeb]) as [ID1],
dense_Rank() over(partition by t1.[refunite] order by t1.[datedeb]) as [ID2],
t1.[Dossier]
,t1.[refmouvement]
,t1.[refadmission]
,t1.[refunite]
,t1.[datedeb]
,t1.[datefin]
,t2.[refmouvement] as [prev_refmouvement]
,t2.refunite as prev_refunite
FROM [sometable] t1
LEFT OUTER JOIN [sometable] t2 /*self join*/
ON t2.datefin = t1.datedeb
AND t1.[refadmission] = t2.[refadmission]
ORDER BY
t1.[datedeb]
這是它給了我:
+-----+-----+---------+--------------+--------------+----------+------------+------------+-------------------+---------------+
| ID1 | ID2 | Dossier | refmouvement | refadmission | refunite | datedeb | datefin | prev_refmouvement | prev_refunite |
+-----+-----+---------+--------------+--------------+----------+------------+------------+-------------------+---------------+
| 1 | 1 | P0| 2567 | 1234 | 227 | 2012-01-01 | 2012-01-02 | NULL | NULL |
| 2 | 2 | P0| 2568 | 1234 | 227 | 2012-01-02 | 2012-01-03 | 2567 | 227 |
| 3 | 1 | P0| 2569 | 1234 | 224 | 2012-01-03 | 2012-01-06 | 2568 | 227 |
| 4 | 1 | P0| 2570 | 1234 | 232 | 2012-01-06 | 2012-01-10 | 2569 | 224 |
| 5 | 2 | P0| 2571 | 1234 | 232 | 2012-01-10 | 2012-01-15 | 2570 | 232 |
| 6 | 3 | P0| 2572 | 1234 | 232 | 2012-01-15 | 2012-01-20 | 2571 | 232 |
| 7 | 4 | P0| 2573 | 1234 | 232 | 2012-01-20 | 2012-01-25 | 2572 | 232 |
| 8 | 2 | P0| 2574 | 1234 | 224 | 2012-01-25 | 2012-01-29 | 2573 | 232 |
| 9 | 3 | P0| 2575 | 1234 | 227 | 2012-01-29 | 2012-02-05 | 2574 | 224 |
| 10 | 4 | P0| 2576 | 1234 | 227 | 2012-02-05 | 2012-02-10 | 2575 | 227 |
| 11 | 5 | P0| 2577 | 1234 | 232 | 2012-02-10 | 2012-02-15 | 2576 | 227 |
| 12 | 1 | P0| 2578 | 1234 | 201 | 2012-02-15 | 2012-02-26 | 2577 | 232 |
+-----+-----+---------+--------------+--------------+----------+------------+------------+-------------------+---------------+
Shaz
WOW!這很棒!非常感謝!這將幫助我節省大量時間!你們真的很精英! :) – iamshazi 2013-04-21 13:56:29