반응형
250x250
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 |
Tags
- 대구카페
- 서울맛집
- 들안길삼겹살
- 큐
- 압구정데이트
- 별찍기
- 수성못맛집
- 수성구데이트
- 반복문
- oracle
- 대구맛집
- programmers
- 수성못삼겹살
- C#
- 조건문
- 범어동맛집
- 대구삼겹살
- 앞산카페
- 대구고깃집
- 대구데이트
- BFS
- 브루트 포스
- SQL
- 안지랑카페
- 프로그래머스
- 오라클
- 대명동맛집
- 정렬
- 수성구맛집
- 백준
Archives
- Today
- Total
모든 일상
Oracle 프로그래머스 Lv2. 카테고리 별 상품 개수 구하기 본문
728x90
반응형
문제 설명
다음은 어느 의류 쇼핑몰에서 판매중인 상품들의 정보를 담은 PRODUCT 테이블입니다. PRODUCT 테이블은 아래와 같은 구조로 되어있으며, PRODUCT_ID, PRODUCT_CODE, PRICE는 각각 상품 ID, 상품코드, 판매가를 나타냅니다.
Column name | Type | Nullable |
PRODUCT_ID | INTEGER | FALSE |
PRODUCT_CODE | VARCHAR(8) | FALSE |
PRICE | INTEGER | FALSE |
상품 별로 중복되지 않는 8자리 상품코드 값을 가지며, 앞 2자리는 카테고리 코드를 의미합니다.
문제
PRODUCT 테이블에서 상품 카테고리 코드(PRODUCT_CODE 앞 2자리) 별 상품 개수를 출력하는 SQL문을 작성해주세요. 결과는 상품 카테고리 코드를 기준으로 오름차순 정렬해주세요.
예시
예를 들어 PRODUCT 테이블이 다음과 같다면
PRODUCT_ID | PRODUCT_CODE | PRICE |
1 | A1000011 | 10000 |
2 | A1000045 | 9000 |
3 | C3000002 | 22000 |
4 | C3000006 | 15000 |
5 | C3000010 | 30000 |
6 | K1000023 | 17000 |
상품 카테고리 코드 별 상품은 아래와 같으므로,
- A1: PRODUCT_ID가 1, 2 인 상품
- C3: PRODUCT_ID가 3, 4, 5 인 상품
- K1: PRODUCT_ID가 6 인 상품
다음과 같은 결과가 나와야 합니다.
CATEGORY | PRODUCTS |
A1 | 2 |
C3 | 3 |
K1 | 1 |
풀이
SELECT SUBSTR(PRODUCT_CODE,0,2) CATEGORY, COUNT(PRODUCT_ID) PRODUCT
FROM PRODUCT
GROUP BY SUBSTR(PRODUCT_CODE,0,2)
ORDER BY 1
SUBSTR(문자열, 2)이면 2번째부터 끝자리까지 문자열을 잘라내지만,
SUBSTR(문자열, 0, 2)이면 0부터 2번째 자리까지 문자열을 잘라낸다는 뜻입니다. 즉 SUBSTR() 에서 원하는 영역을 하나만 지정해주면 그 부분부터 끝까지 잘라내고, 2개의 영역을 지정하면 그 사이의 문자열을 잘라냅니다.
728x90
반응형
'코딩 공부 > Oracle' 카테고리의 다른 글
Oracle 프로그래머스 Lv2. 진료과목별 총 예약 횟수 출력하기 (0) | 2023.03.08 |
---|---|
Oracle 프로그래머스 Lv2. 3월에 태어난 여성 회원 목록 출력하기 (0) | 2023.03.07 |
Oracle 프로그래머스 Lv2. 입양 시각 구하기(1) (0) | 2023.03.07 |
Oracle 프로그래머스 Lv2. 중성화 여부 파악하기 (0) | 2023.03.07 |
Oracle 프로그래머스 Lv2. 고양이와 개는 몇 마리 있을까 (0) | 2023.03.07 |