코딩테스트/SQL
프로그래머스_그룹별 조건에 맞는 식당 목록 출력하기
zyin
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