728x90
[SQL] COUNT() 함수의 최대값 혹은 최대값을 가지는 값 찾기
count()의 최대값 찾기
SELECT COUNT(COLUMN1) AS MAX
FROM TEST
GROUP BY COLUMN1
ORDER BY MAX DESC
LIMIT 1;
desc로 내림차순 정렬한 후, 반환 결과를 limit1으로 제한하여 가장 상단에 있는 값을 출력한다.
count()의 최대값을 가지는 값 찾기
SELECT COLUMN2
FROM TEST
GROUP BY COLUMN1
ORDER BY COUNT(COLUMN1) DESC
LIMIT 1;
order by절에서만 사용하고 출력 결과만 select하여 출력한다.
limit 1로 제한하였으므로 최대값을 지니는 값이 두 개여도 하나만 출력되는 단점이 있는데
Having 절을 사용하여 count의 최대값을 지니는 값을 찾는다.
SELECT COLUMN2
FROM TEST
GROUP BY COLUMN2
HAVING COUNT(COLUMN2) = (SELECT COUNT(COLUMN2)
FROM TEST
GROUP BY COLUMN2
ORDER BY COUNT(COLUMN2) DESC
LIMIT 1);
사용 예시
다음은 고객의 정보를 담은 MEMBER_PROFILE테이블과 식당의 리뷰 정보를 담은 REST_REVIEW테이블입니다.
MEMBER_PROFILE 테이블은 다음과 같으며 MEMBER_ID, MEMBER_NAME, TLNO, GENDER, DATE_OF_BIRTH 는 회원 ID, 회원 이름, 회원 연락처, 성별, 생년월일을 의미합니다.
REST_REVIEW 테이블은 다음과 같으며 REVIEW_ID, REST_ID, MEMBER_ID, REVIEW_SCORE, REVIEW_TEXT, REVIEW_DATE는 각각 리뷰 ID, 식당 ID, 회원 ID, 점수, 리뷰 텍스트, 리뷰 작성일을 의미합니다.
MEMBER_PROFILE와 REST_REVIEW 테이블에서 리뷰를 가장 많이 작성한 회원의 리뷰들을 조회하는 SQL문을 작성해주세요. 회원 이름, 리뷰 텍스트, 리뷰 작성일이 출력되도록 작성해주시고, 결과는 리뷰 작성일을 기준으로 오름차순, 리뷰 작성일이 같다면 리뷰 텍스트를 기준으로 오름차순 정렬해주세요.
SELECT M.MEMBER_NAME, R.REVIEW_TEXT, DATE_FORMAT(R.REVIEW_DATE, '%Y-%m-%d') AS REVIEW_DATE
FROM REST_REVIEW R
JOIN MEMBER_PROFILE M ON R.MEMBER_ID = M.MEMBER_ID
WHERE R.MEMBER_ID = (SELECT MEMBER_ID
FROM REST_REVIEW
GROUP BY MEMBER_ID
ORDER BY COUNT(*) DESC
LIMIT 1)
ORDER BY REVIEW_DATE, REVIEW_TEXT
참고
https://cloudysky.tistory.com/52
https://school.programmers.co.kr/learn/courses/30/lessons/131124
반응형
'💾 Data > SQL' 카테고리의 다른 글
[MySQL] DATE_FORMAT (0) | 2023.11.21 |
---|---|
[MySQL] 문자열 함수 (1) | 2023.11.09 |
[MySQL] REGEXP (0) | 2023.11.07 |
[MySQL] 재귀 쿼리(Recursive) (0) | 2023.11.06 |
[MySQL] NULL 처리 (0) | 2023.11.03 |