Notice
Recent Posts
Recent Comments
Link
Welcome! Everything is fine.
[프로그래머스/Lv.4] 년, 월, 성별 별 상품 구매 회원 수 구하기 - MySQL 본문
728x90
📌 문제
📌 제출한 오답
상품을 구매한 회원 수를 센 COUNT(USER_ID)에서 중복을 제거하는 DISTINCT 키워드를 넣지 않았다. ONLINE_SALE 테이블에 중복된 USER가 존재하기 때문에 DISTINCT를 이용해 중복을 제거해야 한다.
SELECT YEAR(SALES_DATE) AS YEAR
, MONTH(SALES_DATE) AS MONTH
, GENDER
, COUNT(USER_ID) AS USERS
FROM USER_INFO JOIN ONLINE_SALE USING(USER_ID)
WHERE GENDER IS NOT NULL
GROUP BY 1, 2, 3
ORDER BY 1, 2, 3
📌 정답
날짜 데이터는 YEAR, MONTH와 같은 함수로 처리하고, 두 테이블을 USER_ID 기준으로 JOIN하였다. 성별 정보가 없는경우 결과에서 제외해야하기 때문에 WHERE절에서 그 조건을 추가하였다. GROUP BY와 ORDER BY의 1, 2, 3은 SELECT절의 컬럼을 순서대로 적은 것이다.
SELECT YEAR(SALES_DATE) AS YEAR
, MONTH(SALES_DATE) AS MONTH
, GENDER
, COUNT(DISTINCT USER_ID) AS USERS
FROM USER_INFO JOIN ONLINE_SALE USING(USER_ID)
WHERE GENDER IS NOT NULL
GROUP BY 1, 2, 3
ORDER BY 1, 2, 3
'프로그래머스 > SQL' 카테고리의 다른 글
[프로그래머스/Lv.1] 자동차 대여 기록에서 장기/단기 대여 구분하기 - MySQL (0) | 2024.04.12 |
---|---|
[프로그래머스/Lv.3] 조회수가 가장 많은 중고거래 게시판의 첨부파일 조회하기 - MySQL (0) | 2024.04.12 |
[프로그래머스/Lv.4] 서울에 위치한 식당 목록 출력하기 - MySQL (0) | 2024.04.11 |
[프로그래머스/Lv.1] 한 해에 잡은 물고기 수 구하기 - MySQL (0) | 2024.04.11 |
[프로그래머스/Lv.2] ROOT 아이템 구하기 - MySQL (0) | 2024.04.09 |