인프런 커뮤니티 질문&답변

seocoach님의 프로필 이미지
seocoach

작성한 질문수

[백문이불여일타] 데이터 분석을 위한 고급 SQL 문제풀이

고생하셨습니다!

SET4의 3번 자리바꾸기 문제 다른 풀이

작성

·

67

0

선생님 강의 듣기 전에 나름대로 짱구를 굴려서 풀어 봤는데

기본적으로 case when ~~~ 는 똑같지만

lag, lead 함수를 활용해서 해도 문제 풀 수 있었어서

공부하시는 분들과 같이 공유합니다.

select
    id
    , case when mod(id, 2) = 1 and id in (select max(id) from seat) then student
           when mod(id, 2) = 0 then lag_stu
           when mod(id, 2) = 1 then lead_stu
      end as student
from (
        select 
            a.id
            , a.student
            , lag(a.student) over(order by id) as lag_stu
            , lead(a.student) over(order by id) as lead_stu
        from seat  a
        where 1=1
     )  a
where 1=1
order by 1

답변 1

0

안녕하세요, 인프런 AI 인턴입니다.
님의 공유해주신 풀이 방식은 laglead 함수를 사용하여 특정 조건에 맞춰 이전 행 또는 다음 행의 데이터를 활용하는 방식입니다. 이는 SQL에서 데이터의 순서에 따라 값을 비교하거나 교체해야 할 때 유용하게 사용할 수 있는 기법으로, 따라서 데이터 분석 작업에서 자주 사용되는 중요한 스킬 중 하나입니다.

lag 함수는 현재 행에서 지정된 수만큼 이전 행의 데이터를 가져오는 함수이고, lead 함수는 현재 행에서 지정된 수만큼 다음 행의 데이터를 가져오는 함수입니다. 여기서는 자리바꾸기 로직을 구현하기 위해 이러한 창 함수를 효과적으로 사용하셨네요.

이런 방식을 통해 데이터 분석을 위한 SQL 사용 능력을 키우고, 다양한 문제 해결 방식을 배우는 것은 매우 중요합니다. 공유해주셔서 감사합니다. 데이터 분석과 SQL 공부에 매우 도움이 될 것 같아요.

seocoach님의 프로필 이미지
seocoach

작성한 질문수

질문하기