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

Donghyun·2024년 7월 25일
0

Code Kata - SQL

목록 보기
24/61
post-thumbnail

링크: https://school.programmers.co.kr/learn/courses/30/lessons/164671

문제 설명

다음은 중고거래 게시판 정보를 담은 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


문제풀이

  • (메인쿼리)USED_GOODS_BOARD 테이블과 USED_GOODS_FILE 테이블을 JOIN
  • WHERE 절에서 서브쿼리 사용해서 VIEWS 가 서브쿼리 결과에 있는 것만 선택
    • (서브쿼리)USED_GOODS_BOARD 테이블에서
    • VIEWS 가 MAX 인 것만 SELECT
  • 이 문제의 핵심인 파일경로를 어떻게 합칠 것이냐?
    • CONCAT 함수로 컬럼과 문자열을 합친다.
  • 마지막으로 FILE_ID 를 기준으로 내림차순 하면 끝!
SELECT
    CONCAT('/home/grep/src/', ugf.BOARD_ID, '/', FILE_ID, FILE_NAME, FILE_EXT) FILE_PATH
FROM USED_GOODS_BOARD ugb
    JOIN USED_GOODS_FILE ugf
    ON ugb.BOARD_ID = ugf.BOARD_ID
WHERE VIEWS IN (SELECT MAX(VIEWS) VIEWS FROM USED_GOODS_BOARD)
ORDER BY FILE_ID DESC
profile
데이터분석 공부 일기~!

0개의 댓글