SQL / T-SQL. Создать диапазоны из чисел - PullRequest
4 голосов
/ 20 марта 2019

У меня есть таблица номеров, например:

  nums
  _____
| 54902 |
| 54903 | 
| 54901 | 
| 54904 | 
| 54905 | 
| 3487  | 
| 3457  | 
| 789   | 
| 790   | 
| 54906 | 
| 791   | 
| 76253 | 

Я хотел бы создать диапазоны из этого набора, например (если это возможно ...):

54901-54906
3487
3457 
789-791
76253

Любые советы

1 Ответ

7 голосов
/ 20 марта 2019

Для получения такого рода диапазонов.Во-первых, вы должны сгруппировать последовательные числа - чтобы достичь этого, вы можете использовать gaps-and-islands подход -.После этого вы можете легко получить номера max и min для каждой группы.

DECLARE @nums TABLE(num int)
INSERT INTO @nums VALUES
( 54902 ),
( 54903 ), 
( 54901 ), 
( 54904 ), 
( 54905 ), 
( 3487  ), 
( 3457  ), 
( 789   ), 
( 790   ), 
( 54906 ), 
( 791   ), 
( 76253 )


SELECT CAST(MIN(num) AS varchar(10)) 
    + CASE WHEN MAX(num) > MIN(num) THEN '-' + CAST(MAX(num) AS varchar(10)) ELSE '' END  
FROM ( 
    SELECT num, num - ROW_NUMBER() OVER (ORDER BY num) AS GRP 
    FROM @nums 
) AS T
GROUP BY GRP

Результат:

---------------------
789-791
3457
3487
54901-54906
76253
...