Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- 1차원 DP
- 2차원 dp
- 99클럽
- @Builder
- @GeneratedValue
- @GenericGenerator
- @NoargsConstructor
- @Transactional
- Actions
- Amazon EFS
- amazon fsx
- Android Studio
- ANSI SQL
- ApplicationEvent
- assertThat
- async/await
- AVG
- AWS
- Azure
- bind
- builder
- button
- c++
- c++ builder
- c03
- Callback
- case when
- CCW
- chat GPT
- CICD
Archives
- Today
- Total
기록
프로그래머스_그룹별 조건에 맞는 식당 목록 출력하기 본문
문제
https://school.programmers.co.kr/learn/courses/30/lessons/131124
풀이
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
'코딩테스트 > SQL' 카테고리의 다른 글
프로그래머스_서울에 위치한 식당 목록 출력하기 (0) | 2023.06.24 |
---|---|
프로그래머스_식품분류별 가장 비싼 식품의 정보 조회하기 (0) | 2023.06.24 |
프로그래머스_조건에 부합하는 중고거래 댓글 조회하기 (0) | 2023.06.24 |
프로그래머스_3월에 태어난 여성 회원 목록 출력하기 (0) | 2023.06.24 |
프로그래머스_입양 시각 구하기(1) (0) | 2022.02.05 |
Comments