這是一個網友在PASS社團問的問題,個人筆記一下
data:image/s3,"s3://crabby-images/bc53c/bc53c7e5325074a2b22e59b30a843707cc71a593" alt=""
以下是我簡單建立資料表的Code
Create Table t1(Amort int,Type int);
Go
Insert Into t1(Amort,Type)
Values
(1,2),(2,3),(3,3),(4,4),(5,4),
(6,1),(7,2),(8,4),(9,4),(10,4),
(11,3);
GO
資料如下圖所示
data:image/s3,"s3://crabby-images/d5154/d5154da16f17fd3d519a92cd244b2d7136b992a5" alt=""
接下來執行取連續範圍的語法
With tb as(
SELECT Amort, Amort - ROW_NUMBER() OVER(ORDER BY Amort) AS Num
FROM t1 Where [type]=4
)
Select * From tb Where Num = (Select max(Num) From tb);
GO
執行結果如下圖所示
data:image/s3,"s3://crabby-images/31682/316827be960ee15a29ba6aeb459bfd710ed42a3d" alt=""
上面會取出Type=4的資料,並取出最後的連號範圍 8 ,9 ,10
我是ROCKdata:image/s3,"s3://crabby-images/2edb1/2edb1ae0d0597b6c866c3d56a30a2cac761e9cc0" alt=""
rockchang@mails.fju.edu.tw