문제 설명
다음은 어느 한 서점에서 판매 중인 도서들의 도서 정보(BOOK), 저자 정보(AUTHOR) 테이블입니다. BOOK 테이블은 각 도서의 정보를 담은 테이블로 아래와 같은 구조로 되어있습니다.
Column name | Type | Nullable | Description |
BOOK_ID | INTEGER | FALSE | 도서 ID |
CATEGORY | VARCHAR(N) | FALSE | 카테고리 (경제, 인문, 소설, 생활, 기술) |
AUTHOR_ID | INTEGER | FALSE | 저자 ID |
PRICE | INTEGER | FALSE | 판매가 (원) |
PUBLISHED_DATE | DATE | FALSE | 출판일 |
'경제' 카테고리에 속하는 도서들의 도서 ID(BOOK_ID), 저자명(AUTHOR_NAME), 출판일(PUBLISHED_DATE) 리스트를 출력하는 SQL문을 작성해주세요. 결과는 출판일을 기준으로 오름차순 정렬해 주세요.
문제 풀이
SELECT BOOK_ID
, AUTHOR_NAME
, DATE_FORMAT(PUBLISHED_DATE, '%Y-%m-%d') PUBLISHED_DATE
FROM BOOK B
LEFT JOIN AUTHOR A
ON B.AUTHOR_ID = A.AUTHOR_ID
WHERE CATEGORY = '경제'
ORDER BY PUBLISHED_DATE;
DATE_FORMAT으로 출판일의 날짜 형식을 변경했으며, LEFT JOIN을 하여 이 저자 정보 테이블을 조인했다. 그리고 WHERE로 경제 카테고리에 속하는 도서들이 출력되게 쿼리를 작성했다.
'SQL > SQL 테스트 연습' 카테고리의 다른 글
프로그래머스 Lv2. 성분으로 구분한 아이스크림 총 주문량 (0) | 2023.08.14 |
---|---|
프로그래머스 Lv2. 루시와 엘라 찾기 (0) | 2023.08.14 |
프로그래머스 MySQL Lv2. 상품 별 오프라인 매출 구하기 (0) | 2023.08.14 |
프로그래머스 MySQL Lv2. 자동차 종류 별 특정 옵션이 포함된 자동차 수 구하기 (0) | 2023.08.14 |
프로그래머스 MySQL Lv2. 진료과별 총 예약 횟수 출력하기 (0) | 2023.08.14 |