首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >1-3,6,8-10,12等格式的级联序列

1-3,6,8-10,12等格式的级联序列
EN

Stack Overflow用户
提问于 2015-07-13 05:43:06
回答 1查看 78关注 0票数 0

我有数字,但没有顺序。如果这些都是顺序的,那么结果应该如下所示。如果我有像1,2,3,6,8,9,10,12等数据我需要的结果是1-3,6,8-10,12

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2015-07-13 05:59:57

代码语言:javascript
运行
复制
declare @Digits table (Value int primary key)
INSERT @Digits VALUES (1),(2),(3),(6),(8),(9),(10),(12)

SELECT STUFF(CONVERT(varchar(max),
(
    SELECT
        ',' + CASE 
            WHEN MIN(Value) = MAX(Value) THEN CONVERT(varchar(10), MIN(Value)) 
            ELSE CONVERT(varchar(10), MIN(Value)) + '-' + CONVERT(varchar(10), MAX(Value)) 
        END
    FROM (SELECT ROW_NUMBER() OVER (ORDER BY Value) AS Seq, Value FROM @Digits) Data
    GROUP BY Value - Seq
    FOR XML PATH('')
)), 1, 1, '') AS Result

SQL Fiddle

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/31376088

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档