250x250
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
- python
- SQL
- 다중공선성
- 반복문
- 한줄for문
- 이중for문
- AB테스트
- 데이터전처리
- 내배캠_학습기록
- 프로그래머스
- 데이터시각화
- map
- Join
- 시각화
- Max
- Set
- 선형회귀
- 내일배움일지
- 리스트
- Leetcode
- SQLD
- 통계학
- 가설검정
- f-string
- ★
- 내일배움캠프
- DATE_SUB
- 아티클스터디
- 태블로
- Til
Archives
- Today
- Total
노력에는 지름길이 없으니까요
프로그래머스 - 그룹별 조건에 맞는 식당 목록 출력하기 본문
728x90
해결일 | 언어 | 레벨 | 테스트명 |
20240715 | SQL | level 4 | 그룹별 조건에 맞는 식당 목록 출력하기 |
링크 : https://school.programmers.co.kr/learn/courses/30/lessons/131124
내 코드
SELECT
MEMBER_NAME
,REVIEW_TEXT
,DATE_FORMAT(REVIEW_DATE,'%Y-%m-%d') REVIEW_DATE
FROM REST_REVIEW
JOIN MEMBER_PROFILE
USING (MEMBER_ID)
# 2. 개수가 MAX 개수인 모든 MEMBER_ID를 구하는 서브쿼리
WHERE MEMBER_ID IN (SELECT MEMBER_ID
FROM REST_REVIEW
GROUP BY MEMBER_ID
# 1. MAX 개수를 구하는 서브쿼리
HAVING COUNT(REVIEW_ID) = (SELECT COUNT(REVIEW_ID) CNT
FROM REST_REVIEW
GROUP BY MEMBER_ID
ORDER BY COUNT(REVIEW_ID) DESC
LIMIT 1))
ORDER BY 3,2
1. 서브쿼리에서 구할 수 있는 MAX 개수는 3
2. 따라서 포스트 수가 3개인 모든 MEMBER에 대한 글을 출력하면 된다.
에러 없이 한 번에 풀려서 기분 좋다 ㅎㅎ
개선점:
MAX를 구하는 방식에서 나는 DESC LIMIT1을 사용하는 다소 번거로운 방법을 썼는데,
그냥 MAX 함수를 쓰면 될 일이다...
베스트 코드
WITH REVIEW_COUNT_BY_MEMBER AS (
SELECT MEMBER_ID, COUNT(*) AS REVIEW_COUNT
FROM REST_REVIEW
GROUP BY MEMBER_ID
),
MAX_REVIEW_COUNT AS (
SELECT MEMBER_ID
FROM REVIEW_COUNT_BY_MEMBER
WHERE REVIEW_COUNT = (SELECT MAX(REVIEW_COUNT) FROM REVIEW_COUNT_BY_MEMBER)
)
SELECT
MP.MEMBER_NAME,
RR.REVIEW_TEXT,
DATE_FORMAT(RR.REVIEW_DATE, '%Y-%m-%d') AS REVIEW_DATE
FROM
MAX_REVIEW_COUNT AS MRC
JOIN MEMBER_PROFILE AS MP ON MRC.MEMBER_ID = MP.MEMBER_ID
JOIN REST_REVIEW AS RR ON MRC.MEMBER_ID = RR.MEMBER_ID
ORDER BY
REVIEW_DATE ASC,
REVIEW_TEXT ASC;
728x90
반응형
'SQL > 프로그래머스' 카테고리의 다른 글
프로그래머스 - 자동차 대여 기록에서 대여중 / 대여 가능 여부 구분하기 (0) | 2024.08.01 |
---|---|
프로그래머스 - 우유와 요거트가 담긴 장바구니 (0) | 2024.07.16 |
프로그래머스 - 배열 만들기 1 (0) | 2024.07.12 |
프로그래머스 - 가격대 별 상품 개수 구하기 (0) | 2024.07.10 |
프로그래머스 - 식품분류별 가장 비싼 식품의 정보 조회하기 (0) | 2024.07.10 |