sql组只能按顺序排列

前端之家收集整理的这篇文章主要介绍了sql组只能按顺序排列前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
说我有下表:
  1. MyTable
  2. ---------
  3. | 1 | A |
  4. | 2 | A |
  5. | 3 | A |
  6. | 4 | B |
  7. | 5 | B |
  8. | 6 | B |
  9. | 7 | A |
  10. | 8 | A |
  11. ---------

我需要SQL查询输出以下内容

  1. ---------
  2. | 3 | A |
  3. | 3 | B |
  4. | 2 | A |
  5. ---------

基本上我正在做一个组,但是只是为了排列在一起的行.有任何想法吗?

请注意,数据库sql Server 2008上.有一个关于这个主题的帖子,但是它使用oracle的lag()函数.

解决方法

这被称为“岛屿”问题.使用Itzik Ben Gan的方法
  1. ;WITH YourTable AS
  2. (
  3. SELECT 1 AS N,'A' AS C UNION ALL
  4. SELECT 2 AS N,'A' AS C UNION ALL
  5. SELECT 3 AS N,'A' AS C UNION ALL
  6. SELECT 4 AS N,'B' AS C UNION ALL
  7. SELECT 5 AS N,'B' AS C UNION ALL
  8. SELECT 6 AS N,'B' AS C UNION ALL
  9. SELECT 7 AS N,'A' AS C UNION ALL
  10. SELECT 8 AS N,'A' AS C
  11. ),T
  12. AS (SELECT N,C,DENSE_RANK() OVER (ORDER BY N) -
  13. DENSE_RANK() OVER (PARTITION BY C ORDER BY N) AS Grp
  14. FROM YourTable)
  15. SELECT COUNT(*),C
  16. FROM T
  17. GROUP BY C,Grp
  18. ORDER BY MIN(N)

猜你在找的MsSQL相关文章