코딩테스트/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의 암묵 형변환으로 별다른 형변환 없이 텍스트 형식으로 비교가 가능함