[프로그래머스][SQL] 조건별로 분류하여 주문상태 출력하기

Eunding·2024년 2월 28일
0

SQL 고득점 Kit

목록 보기
52/62

조건별로 분류하여 주문상태 출력하기

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

문제

FOOD_ORDER 테이블에서 5월 1일을 기준으로 주문 ID, 제품 ID, 출고일자, 출고여부를 조회하는 SQL문을 작성해주세요. 출고여부는 5월 1일까지 출고완료로 이 후 날짜는 출고 대기로 미정이면 출고미정으로 출력해주시고, 결과는 주문 ID를 기준으로 오름차순 정렬해주세요.

예시

풀이

SELECT ORDER_ID, PRODUCT_ID, DATE_FORMAT(OUT_DATE,'%Y-%m-%d') AS OUT_DATE, 
    (CASE 
        WHEN OUT_DATE IS NULL THEN '출고미정'
        WHEN OUT_DATE > '2022-05-01' THEN '출고대기'
        ELSE '출고완료' 
     END) AS '출고여부'
FROM FOOD_ORDER
ORDER BY ORDER_ID
  1. 5월 1일 기준으로 출고 여부 표시
    => CASE문으로 OUT_DATE가 2022년 5월 1일 이후면 '출고 대기', NULL이면 '출고미정'
    두 경우 모두 아니면(2022년 5월 1일 이전이면) '출고 완료'의 값으로 '출고여부'컬럼을 지정
  2. 주문 ID를 기준으로 오름차순 정렬
    => ORDER BY 이용
profile
안녕하세요~

0개의 댓글