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
- 프로그래머스
- MySQL
- java
- 자바
- Kotlin
- groupby
- doitandroid
- 인프런
- 혼공단
- 안드로이드
- 기술면접
- 정보처리기사
- select
- 정처기
- 오블완
- CS
- SQL
- 스터디
- 티스토리챌린지
- join
- 코테
- 자료구조
- 알고리즘
- Android
- 혼공챌린지
- Til
- 혼공파
- 카카오코테
- 코틀린
- 안드로이드스튜디오
Archives
- Today
- Total
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 |