[프로그래머스] Lv.3 조회수가 가장 많은 중고거래 게시판의 첨부파일 조회하기 MySQL

Janet·2023년 5월 8일
0

SQL

목록 보기
3/4

문제 설명

다음은 중고거래 게시판 정보를 담은 USED_GOODS_BOARD 테이블과 중고거래 게시판 첨부파일 정보를 담은 USED_GOODS_FILE 테이블입니다. USED_GOODS_BOARD 테이블은 다음과 같으며 BOARD_IDWRITER_IDTITLECONTENTSPRICECREATED_DATESTATUSVIEWS은 게시글 ID, 작성자 ID, 게시글 제목, 게시글 내용, 가격, 작성일, 거래상태, 조회수를 의미합니다.

Column nameTypeNullable
BOARD_IDVARCHAR(5)FALSE
WRITER_IDVARCHAR(50)FALSE
TITLEVARCHAR(100)FALSE
CONTENTSVARCHAR(1000)FALSE
PRICENUMBERFALSE
CREATED_DATEDATEFALSE
STATUSVARCHAR(10)FALSE
VIEWSNUMBERFALSE

USED_GOODS_FILE 테이블은 다음과 같으며 FILE_IDFILE_EXTFILE_NAMEBOARD_ID는 각각 파일 ID, 파일 확장자, 파일 이름, 게시글 ID를 의미합니다.

Column nameTypeNullable
FILE_IDVARCHAR(10)FALSE
FILE_EXTVARCHAR(5)FALSE
FILE_NAMEVARCHAR(256)FALSE
BOARD_IDVARCHAR(10)FALSE

문제

USED_GOODS_BOARD와 USED_GOODS_FILE 테이블에서 조회수가 가장 높은 중고거래 게시물에 대한 첨부파일 경로를 조회하는 SQL문을 작성해주세요. 첨부파일 경로는 FILE ID를 기준으로 내림차순 정렬해주세요. 기본적인 파일경로는 /home/grep/src/ 이며, 게시글 ID를 기준으로 디렉토리가 구분되고, 파일이름은 파일 ID, 파일 이름, 파일 확장자로 구성되도록 출력해주세요. 조회수가 가장 높은 게시물은 하나만 존재합니다.


예시

USED_GOODS_BOARD 테이블이 다음과 같고

BOARD_IDWRITER_IDTITLECONTENTSPRICECREATED_DATESTATUSVIEWS
B0001kwag98반려견 배변패드 팝니다정말 저렴히 판매합니다. 전부 미개봉 새상품입니다.120002022-10-01DONE250
B0002lee871201국내산 볶음참깨직접 농사지은 참깨입니다.30002022-10-02DONE121
B0003goung12배드민턴 라켓사놓고 방치만 해서 팝니다.90002022-10-02SALE212
B0004keel1990디올 귀걸이신세계강남점에서 구입. 정품 아닐시 백퍼센트 환불1300002022-10-02SALE199
B0005haphli01스팸클래식 팔아요유통기한 2025년까지에요100002022-10-02SALE121

USED_GOODS_FILE 테이블이 다음과 같을 때

FILE_IDFILE_EXTFILE_NAMEBOARD_ID
IMG_000001.jpgphoto1B0001
IMG_000002.jpgphoto2B0001
IMG_000003.png사진B0002
IMG_000004.jpg사진B0003
IMG_000005.jpgphotoB0004

SQL을 실행하면 다음과 같이 출력되어야 합니다.

FILE_PATH
/home/grep/src/B0001/IMG_000001photo1.jpg
/home/grep/src/B0001/IMG_000002photo2.jpg

문제풀이

✅ 답안

SELECT
    CONCAT(
        '/home/grep/src/', F.BOARD_ID, '/', FILE_ID, FILE_NAME, FILE_EXT
    ) AS FILE_PATH
FROM USED_GOODS_FILE AS F
JOIN USED_GOODS_BOARD AS B
ON F.BOARD_ID = B.BOARD_ID
WHERE VIEWS = (SELECT MAX(VIEWS) FROM USED_GOODS_BOARD)
ORDER BY FILE_ID DESC
profile
😸

0개의 댓글