개발하는 자몽

[프로그래머스] 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년에 출판된 동시에 인문 카테고리의 책이어야 하므로 WHEREAND를 사용하고, 인문 카테고리인 경우만 조회하도록 한다.
  3. 출력 시 PUBLISHED_DATE의 날짜 형식이 정해져 있으므로 DATE_FORMAT() 함수로 날짜 형식을 맞춰준다. 함수를 사용한 상태로 바로 출력하면 date_format(PUBLISHED_DATE, '%Y-%m-%d') 이렇게 나오므로 AS를 사용하여 이름을 지정해 준다. 

 

 

 

 

 

Comments