문제
MEMBER_PROFILE와 REST_REVIEW 테이블에서 리뷰를 가장 많이 작성한 회원의 리뷰들을 조회하는 SQL문을 작성해주세요. 회원 이름, 리뷰 텍스트, 리뷰 작성일이 출력되도록 작성해주시고, 결과는 리뷰 작성일을 기준으로 오름차순, 리뷰 작성일이 같다면 리뷰 텍스트를 기준으로 오름차순 정렬해주세요.
테이블 설명
MEMBER_PROFILE
Column name | Type | Nullable | Desc |
---|
MEMBER_ID | VARCHAR(100) | FALSE | 회원 ID |
MEMBER_NAME | VARCHAR(50) | FALSE | 회원 이름 |
TLNO | VARCHAR(50) | TRUE | 회원 연락처 |
GENDER | VARCHAR(1) | TRUE | 성별 |
DATE_OF_BIRTH | DATE | TRUE | 생년월일 |
REST_REVIEW
Column name | Type | Nullable | Desc |
---|
REVIEW_ID | VARCHAR(10) | FALSE | 리뷰 ID |
REST_ID | VARCHAR(10) | TRUE | 식당 ID |
MEMBER_ID | VARCHAR(100) | TRUE | 회원 ID |
REVIEW_SCORE | NUMBER | TRUE | 점수 |
REVIEW_TEXT | VARCHAR(1000) | TRUE | 리뷰 텍스트 |
REVIEW_DATE | DATE | TRUE | 리뷰 작성일 |
주의사항
- REVIEW_DATE의 데이트 포맷이 예시와 동일해야 정답처리 됩니다.
예시 : 2022-02-12
내가 제출한 SQL문
WITH MOST_MAX_CNT AS (
SELECT
MAX(A.CNT) AS 'MAX_CNT'
FROM (SELECT
R.MEMBER_ID
,COUNT(R.MEMBER_ID) AS 'CNT'
FROM REST_REVIEW R
GROUP BY R.MEMBER_ID) A
)
, MOST_REVIEW AS (
SELECT
R.MEMBER_ID
,COUNT(R.MEMBER_ID) AS 'CNT'
FROM REST_REVIEW R
GROUP BY R.MEMBER_ID
ORDER BY CNT DESC
)
SELECT
MP.MEMBER_NAME
,RR.REVIEW_TEXT
,DATE_FORMAT(RR.REVIEW_DATE, '%Y-%m-%d') AS 'REVIEW_DATE'
FROM MOST_REVIEW M
JOIN MOST_MAX_CNT MC
ON MC.MAX_CNT = M.CNT
INNER JOIN MEMBER_PROFILE MP
ON M.MEMBER_ID = MP.MEMBER_ID
INNER JOIN REST_REVIEW RR
ON M.MEMBER_ID = RR.MEMBER_ID
ORDER BY REVIEW_DATE ASC, RR.REVIEW_TEXT ASC;
다른 사람 풀이(RANK 함수 사용)
SELECT
MEMBER_NAME
,REVIEW_TEXT
,date_format(REVIEW_DATE,"%Y-%m-%d") as REVIEW_DATE
FROM (
SELECT
MEMBER_ID
,COUNT(MEMBER_ID)
,dense_rank() over(ORDER BY COUNT(MEMBER_ID) DESC) as ran
FROM REST_REVIEW
GROUP BY MEMBER_ID
ORDER BY COUNT(MEMBER_ID) DESC
) A NATURAL JOIN MEMBER_PROFILE JOIN REST_REVIEW USING (MEMBER_ID)
WHERE A.ran =1
ORDER BY REVIEW_DATE,REVIEW_TEXT;
RANK 함수 공부한 사이트
RANK / DENSE_RANK / ROW_NUMBER 차이점