728x90
반응형
https://school.programmers.co.kr/learn/courses/30/lessons/131113
문제 설명
다음은 식품공장의 주문정보를 담은 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
반응형
'코딩테스트 > 프로그래머스' 카테고리의 다른 글
[프로그래머스/ORACLE] 카테고리 별 상품 개수 구하기 (0) | 2024.01.11 |
---|---|
[프로그래머스/ORACLE] 가격이 제일 비싼 식품의 정보 출력하기 (0) | 2024.01.11 |
[프로그래머스/java] 저주의 숫자 3 (0) | 2023.12.19 |
[프로그래머스/MySQL] 자동차 종류 별 특정 옵션이 포함된 자동차 수 구하기 (0) | 2023.06.09 |
[프로그래머스/MySQL] 대여 횟수가 많은 자동차들의 월별 대여 횟수 구하기 (0) | 2023.06.09 |
댓글