최대 1 분 소요

문제 링크

정답

-- USED_GOODS_BOARD: BOARD_ID, WRITER_ID, TITLE, CONTENTS, PRICE, CREATED_DATE, STATUS, VIEWS
-- USED_GOODS_FILE: FILE_ID, FILE_EXT, FILE_NAME, BOARD_ID

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

✅ Point

  • 최다 view: where 문 sub query
    • 문제에서 조회수가 가장 높은 게시물은 하나만 존재한다고 명시
    • 해당 코드는 조회수가 가장 높은 게시물이 여러 개일 때도 적용 가능함
  • CONCAT 을 통한 문자열 붙이기