程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> SqlServer數據庫 >> 關於SqlServer >> SQL查詢連續號碼段的巧妙解法實例講解

SQL查詢連續號碼段的巧妙解法實例講解

編輯:關於SqlServer

本文介紹了一則非常巧妙的SQL技巧,具體內容請參考下文:

問題如下:

有一個表結構:

以下為引用的內容:

fphm,kshm

2014,00000001

2014,00000002

2014,00000003

2014,00000004

2014,00000005

2014,00000007

2014,00000008

2014,00000009

2013,00000120

2013,00000121

2013,00000122

2013,00000124

2013,00000125

(注:第二個字段內可能是連續的數據,也許存在斷點。)

如何才能查詢出來這樣的結果,查詢出連續的記錄來。

類似下面這個示例:

以下為引用的內容:

2014,00000001,00000005

2014,00000009,00000007

2013,00000120,00000122

2013,00000124,00000125

下面是一個很巧妙的解決方法:

SQL> SELECT b.fphm, MIN (b.kshm) Start_HM, MAX (b.kshm) End_HM

2 FROM (SELECT a.*, TO_NUMBER (a.kshm - ROWNUM) cc

3 FROM (SELECT *

4 FROM t

5 ORDER BY fphm, kshm) a) b

6 GROUP BY b.fphm, b.cc

7 /

FPHM START_HM END_HM

---------- -------- --------

2013 00000120 00000122

2013 00000124 00000125

2014 00000001 00000005

2014 00000007 00000009

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved