코딩테스트/SQL 코딩테스트

<프로그래머스> 조건에 부합하는 중고거래 상태 조회하기

배또가또 2023. 12. 22. 21:31

출처 : https://school.programmers.co.kr/learn/courses/30/lessons/164672

 

프로그래머스

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

programmers.co.kr



  • 문제 요구사항
    • USER_GOODS_BOARD 테이블에서 2022년 5월에 등록된 중고거래 게시물의 
    • 게시글 ID, 작성자 ID, 게시글 제목, 가격, 거래 상태를 조회하는 SQL문 작성
    • 만약 거래 상태가 SALE이면 판매중, RESERVED면 예약중, DONE이면 거래완료로 분류하여 거래 상태를 출력
    • 결과는 게시물 ID를 기준으로 내림차순 정렬

WHERE절을 이용해 2022년 5월 게시물로 조건을 한정하고

CASE문을 활용하여 STATUS를 분류하여 출력함


1) Oracle

SELECT BOARD_ID, 
       WRITER_ID, 
       TITLE, 
       PRICE, 
       CASE WHEN STATUS = 'SALE' THEN '판매중'
            WHEN STATUS = 'DONE' THEN '거래완료'
            WHEN STATUS = 'RESERVED' THEN '예약중'
            END STATUS
FROM USED_GOODS_BOARD 
WHERE TO_CHAR(CREATED_DATE, 'YYYY-MM-DD') = '2022-10-05'
ORDER BY BOARD_ID DESC;

2) MySQL

SELECT BOARD_ID, 
       WRITER_ID, 
       TITLE, 
       PRICE, 
       CASE WHEN STATUS = 'SALE' THEN '판매중'
            WHEN STATUS = 'DONE' THEN '거래완료'
            WHEN STATUS = 'RESERVED' THEN '예약중'
            END STATUS
FROM USED_GOODS_BOARD 
WHERE CREATED_DATE = '2022-10-05'
ORDER BY 1 DESC;

 

MySQL의 암묵 형변환으로 별다른 형변환 없이 텍스트 형식으로 비교가 가능함