개발하는 자몽

[프로그래머스] SELECT > 조건에 맞는 도서 리스트 출력하기 본문

SQL

[프로그래머스] SELECT > 조건에 맞는 도서 리스트 출력하기

jaamong 2024. 1. 23. 21:16

문제

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

BOOK 테이블에서 2021년에 출판된 '인문' 카테고리에 속하는 도서 리스트를 찾아서 도서 ID(BOOK_ID), 출판일 (PUBLISHED_DATE)을 출력하는 SQL문을 작성해 주세요.
결과는 출판일을 기준으로 오름차순 정렬해 주세요.

PUBLISHED_DATE의 데이트 포맷이 예시와 동일해야 정답처리 됩니다.

 

풀이

  • 2021년에 출판
  • '인문' 카테고리
  • `BOOK_ID`, `PUBLISHED_DATE` 출력
  • 출판일 기준으로 오름차순 정렬
  • `PUBLISHED_DATE`의 데이트 포맷 확인
SELECT BOOK_ID, DATE_FORMAT(published_date, '%Y-%m-%d') AS PUBLISHED_DATE 
FROM BOOK 
WHERE YEAR(PUBLISHED_DATE) = 2021 AND CATEGORY = '인문'
ORDER BY PUBLISHED_DATE ASC;

 

  1. 2021년에 출판된 책이어야 하므로 `WHERE` 절로 조건을 설정하고, `YEAR()` 함수를 사용하여 연도를 추출한다.
  2. 2021년에 출판된 동시에 인문 카테고리의 책이어야 하므로 `WHERE`에 AND를 사용하고, 인문 카테고리인 경우만 조회하도록 한다.
  3. 출력 시 `PUBLISHED_DATE`의 날짜 형식이 정해져 있으므로 `DATE_FORMAT()` 함수로 날짜 형식을 맞춰준다. 함수를 사용한 상태로 바로 출력하면 `date_format(PUBLISHED_DATE, '%Y-%m-%d')` 이렇게 나오므로 `AS`를 사용하여 이름을 지정해 준다. 

 

 

 

 

 

Comments