본문 바로가기
코딩테스트/프로그래머스

[프로그래머스/Oracle] 조건별로 분류하여 주문상태 출력하기(TO_CHAR, TO_DATE, CASE WHEN)

by drCode 2024. 2. 5.
728x90
반응형

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


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

 

프로그래머스

코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.

programmers.co.kr

 

문제 설명

다음은 식품공장의 주문정보를 담은 FOOD_ORDER 테이블입니다. FOOD_ORDER 테이블은 다음과 같으며 

ORDER_ID, PRODUCT_ID, AMOUNT, PRODUCE_DATE, IN_DATE,OUT_DATE,FACTORY_ID, WAREHOUSE_ID는

각각 주문 ID, 제품 ID, 주문양, 생산일자, 입고일자, 출고일자, 공장 ID, 창고 ID를 의미합니다.

 

문제

FOOD_ORDER 테이블에서 5월 1일을 기준으로

주문 ID, 제품 ID, 출고일자, 출고여부를 조회하는 SQL문을 작성해주세요.

출고여부는 5월 1일까지 출고완료로 이 후 날짜는 출고 대기로 미정이면 출고미정으로 출력해주시고,

결과는 주문 ID를 기준으로 오름차순 정렬해주세요.

 

이 문제는 TO_CHAR, TO_DATE, CASE WHEN 을 이용하여 푸는 문제이다.

 

처음엔 출고여부만 신경써서 풀다가, 계속 오답이 나길래  OUT_DATE의 형식을 봤더니 YYYY-MM-DD 형식이다.

OUT_DATE의 조회 형식도 잘 맞춰줘야 정답으로 처리된다.

 

SELECT    ORDER_ID
        , PRODUCT_ID
        , TO_CHAR(OUT_DATE, 'YYYY-MM-DD') "출고일자"
        , CASE WHEN OUT_DATE <= TO_DATE('20220501', 'YYYYMMDD') THEN '출고완료'
               WHEN OUT_DATE > TO_DATE('20220501', 'YYYYMMDD') THEN '출고대기'
               ELSE '출고미정' END AS "출고여부"
  FROM FOOD_ORDER 
 ORDER BY ORDER_ID ASC

 

 

728x90
반응형

댓글