세조목

SQL 예제(Consecutive Numbers)(Lead 함수) 본문

데이터 분석 공부/SQL

SQL 예제(Consecutive Numbers)(Lead 함수)

세조목 2024. 2. 22. 10:44

LeetCode 180. Consecutive Numbers

https://leetcode.com/problems/consecutive-numbers/description/

WITH CON AS(
    SELECT NUM,
        LEAD(NUM, 1) OVER() NEXT_ORDER,
        LEAD(NUM, 2) OVER() NEXT_ORDER2
    FROM LOGS
)
SELECT DISTINCT NUM CONSECUTIVENUMS
FROM CON
WHERE (NUM=NEXT_ORDER) AND (NUM=NEXT_ORDER2)

 

Consecutive Number란 연속된 숫자라는 의미다.

예를들어 위와같은 테이블이 있다고했을때

num 컬럼에서 3번 연속으로 동일하게 입력된 숫자를 찾는 것이 문제의 요구사항이다.

어떻게 구할 수 있을까?

 

연속적인 수인지를 판별하기위해서 lead함수를 활용할 수 있다.

lead함수란 특정 컬럼의 특정 행에서 그 다음 행의 값을 확인할 수 있는 함수다.

만약 아래와같이 num이 1, 2, 3인 테이블이 있다고했을때 lead 함수를 적용하면

2, 3, null이 출력된다.

num next_num
1 2
2 3
3 null

 

lead함수를 예제에 적용해보자

lead함수를 사용하여 num 컬럼 옆에 두번째 열부터 시작하는 컬럼과 세번째 열부터 시작하는 컬럼을 만들어준다.

num과 num_next, num_next2에 모두 같은 값이 들어와있으면 3번 연속 같은 값이 출력됐다고 볼 수 있다.

이를 where절에 쿼리로 작성하면 아래와 같다.

WHERE (NUM=NUM_NEXT) AND (NUM_NEXT=NUM_NEXT2)

 

위의 where절을 반영한 최종 쿼리는 아래와 같이 작성해볼 수 있다.

WITH CON AS(
    SELECT NUM,
        LEAD(NUM, 1) OVER() NUM_NEXT,
        LEAD(NUM, 2) OVER() NUM_NEXT2
    FROM LOGS
)
SELECT DISTINCT NUM CONSECUTIVENUMS
FROM CON
WHERE (NUM=NUM_NEXT) AND (NUM_NEXT=NUM_NEXT2);