sql - 최대 - 오라클 최근 값 가져 오기




순차적 인 행만을 기준으로 SQL 그룹 (2)

이것은 "섬"문제로 알려져 있습니다. 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)

다음 표가 있다고 가정 해보십시오.

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 () 함수가 사용됩니다.


이것은 당신을 위해 작동합니다 ...

SELECT 
  Total=COUNT(*), C 
FROM 
(
 SELECT 
 NGroup = ROW_NUMBER() OVER (ORDER BY N) - ROW_NUMBER() OVER (PARTITION BY C ORDER BY N),
 N,
 C
 FROM MyTable 
)RegroupedTable
GROUP BY C,NGroup




gaps-and-islands