기록

프로그래머스_그룹별 조건에 맞는 식당 목록 출력하기 본문

코딩테스트/SQL

프로그래머스_그룹별 조건에 맞는 식당 목록 출력하기

youngyin 2023. 6. 24. 22:43

문제

https://school.programmers.co.kr/learn/courses/30/lessons/131124

 

프로그래머스

코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.

programmers.co.kr

풀이

with절의 사용

Oracle에서의 WITH 절은 임시 결과 집합을 만드는 데 사용된다.

WITH 절은 쿼리의 가독성을 향상시키고, 중복 코드를 줄이며, 복잡한 쿼리를 단순화하는 데 도움을 준다.

아래처럼 사용할 수 있다.

WITH <cte_name1> AS (
  <cte_query>
), <cte_name2> AS (
  <cte_query>
), <cte_name3> AS (
  <cte_query>
)
SELECT <columns>
FROM <tables>
JOIN <cte_name1> ON <join_conditions>
JOIN <cte_name2> ON <join_conditions>
JOIN <cte_name3> ON <join_conditions>
WHERE <conditions>

Rank 함수

윈도우 함수는 데이터를 그룹화하거나 정렬하는 데 사용되는 함수로, 행 단위로 동작한다.

<윈도우 함수>(<표현식>) OVER (
  [PARTITION BY <열1>, <열2>, ...]
  [ORDER BY <정렬 열1> [ASC|DESC], <정렬 열2> [ASC|DESC], ...]
  [ROWS <윈도우 프레임>]
)
  •  PARTITION BY 절은 데이터를 그룹화할 기준 열을 지정한다.
  • ORDER BY 절은 데이터의 정렬 순서를 지정한다.
  • ROWS 절은 윈도우 프레임을 지정하여 계산할 행의 범위를 제한한다.

코드

WITH C AS(
    -- 사용자 별 리뷰수 랭킹정보
    SELECT 
        MEMBER_ID, 
        RANK() OVER (ORDER BY COUNT DESC) AS RANK
    FROM (
        SELECT MEMBER_ID, COUNT(REVIEW_ID) AS COUNT
        FROM REST_REVIEW
        GROUP BY MEMBER_ID 
    )
)
SELECT 
    P.MEMBER_NAME, 
    R.REVIEW_TEXT, 
    TO_CHAR(R.REVIEW_DATE, 'YYYY-MM-DD') AS REVIEW_DATE
FROM MEMBER_PROFILE P
INNER JOIN REST_REVIEW R ON P.MEMBER_ID = R.MEMBER_ID
INNER JOIN C ON P.MEMBER_ID = C.MEMBER_ID
WHERE C.RANK = 1
ORDER BY R.REVIEW_DATE, R.REVIEW_TEXT
Comments