連続する行のみをグループ化するSQL 質問する

連続する行のみをグループ化する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 |
---------

group by基本的に、シーケンス内で一緒になっている行に対してのみ実行します。何かアイデアはありますか?

データベースは SQL Server 2008 上にあることに注意してください。このトピックに関する投稿がありますが、Oracle の lag() 関数が使用されています。

ベストアンサー1

これは「島」問題として知られています。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)

おすすめ記事