문제

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

 



* 가격대 구간을 구하는 게 핵심

* case when을 활용해서 10,000 미만은 0, 나머지는 truncate 함수 사용해서 자르기

 

 

 

풀이

select (case when price < 10000 then 0
       else truncate(price, -4) end) as price_group, 
       count(*) as products /* count(product_id) */
from product
group by price_group
order by price_group

 

+ Recent posts