sql组只能按顺序排列

我有下表:
MyTable
---------
| 1 | A |
| 2 | A |
| 3 | A |
| 4 | B |
| 5 | B |
| 6 | B |
| 7 | A |
| 8 | A |
---------

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

---------
| 3 | A |
| 3 | B |
| 2 | A |
---------

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

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

解决方法

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

相关文章

SELECT a.*,b.dp_name,c.pa_name,fm_name=(CASE WHEN a.fm_n...
if not exists(select name from syscolumns where name=&am...
select a.*,pano=a.pa_no,b.pa_name,f.dp_name,e.fw_state_n...
要在 SQL Server 2019 中设置定时自动重启,可以使用 Window...
您收到的错误消息表明数据库 'EastRiver' 的...
首先我需要查询出需要使用SQL Server Profiler跟踪的数据库标...