Road to Data Scientist

[프로그래머스] 가격대 별 상품 개수 구하기 Lv.2 본문

코딩 테스트/SQL

[프로그래머스] 가격대 별 상품 개수 구하기 Lv.2

ShazelP 2024. 6. 9. 18:31

가격대 별 상품 개수 구하기

 

PRODUCT 테이블

- PRODUCT_ID: 상품 아이디

- PRODUCT_CODE: 상품 코드

- PRICE: 판매가

 

문제

PRODUCT 테이블에서 만원 단위의 가격대 별로 상품 개수를 출력하는 SQL 문을 작성해주세요. 이때 컬럼명은 각각 컬럼명은 PRICE_GROUP, PRODUCTS로 지정해주시고 가격대 정보는 각 구간의 최소금액(10,000원 이상 ~ 20,000 미만인 구간인 경우 10,000)으로 표시해주세요. 결과는 가격대를 기준으로 오름차순 정렬해주세요.

 

정답 예시

 

코드

SELECT FLOOR(PRICE/10000) * 10000 AS PRICE_GROUP, COUNT(*) AS PRODUCTS
FROM PRODUCT
GROUP BY PRICE_GROUP
ORDER BY PRICE_GROUP

 

설명

1. PRODUCT 테이블에서

2. PRICE와 총 개수 COUNT(*) 를 추출하는데

2.1 만원단위의 가격대 설정을 위해 PRICE/10000 후 몫만 구하기 위해 FLOOR(PRICE/10000) 하면 0,1,2,... 가 나오므로 이 값에 10000을 곱하면 만원단위 가격대를 구할 수 있다.

2.2 그리고 각 칼럼명을 AS PRICE_GROUP, AS PRODUCT 로 설정

3. 총 개수를 구하기 위한 기준을 정하기 위해 GROUP BY PRICE_GROUP 설정

4. 최종 결과를 PRICE_GROUP 으로 정렬

 

+FLOOR 함수

- 소수점 첫째자리에서 반올림이 아닌 그냥 버리는 함수

- Ex: FLOOR(2.3) = 2, FLOOR(3.5) = 3

+ROUND 함수

- 반올림 해줌

 

출처

https://school.programmers.co.kr/learn/courses/30/lessons/131530

 

프로그래머스

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

programmers.co.kr