Welcome! Everything is fine.

[프로그래머스/Lv.4] 년, 월, 성별 별 상품 구매 회원 수 구하기 - MySQL 본문

프로그래머스/SQL

[프로그래머스/Lv.4] 년, 월, 성별 별 상품 구매 회원 수 구하기 - MySQL

개발곰발 2024. 4. 11.
728x90

📌 문제

 

프로그래머스

코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.

programmers.co.kr

📌 제출한 오답

상품을 구매한 회원 수를 센 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