diff --git a/프로그래머스/3/164671. 조회수가 가장 많은 중고거래 게시판의 첨부파일 조회하기/README.md b/프로그래머스/3/164671. 조회수가 가장 많은 중고거래 게시판의 첨부파일 조회하기/README.md new file mode 100644 index 0000000..5251af4 --- /dev/null +++ b/프로그래머스/3/164671. 조회수가 가장 많은 중고거래 게시판의 첨부파일 조회하기/README.md @@ -0,0 +1,234 @@ +# [level 3] 조회수가 가장 많은 중고거래 게시판의 첨부파일 조회하기 - 164671 + +[문제 링크](https://school.programmers.co.kr/learn/courses/30/lessons/164671) + +### 성능 요약 + +메모리: 0.0 MB, 시간: 0.00 ms + +### 구분 + +코딩테스트 연습 > String, Date + +### 채점결과 + +Empty + +### 제출 일자 + +2025년 03월 02일 13:10:17 + +### 문제 설명 + +

다음은 중고거래 게시판 정보를 담은 USED_GOODS_BOARD 테이블과 중고거래 게시판 첨부파일 정보를 담은 USED_GOODS_FILE 테이블입니다. USED_GOODS_BOARD 테이블은 다음과 같으며 BOARD_ID, WRITER_ID, TITLE, CONTENTS, PRICE, CREATED_DATE, STATUS, VIEWS은 게시글 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_ID, FILE_EXT, FILE_NAME, BOARD_ID는 각각 파일 ID, 파일 확장자, 파일 이름, 게시글 ID를 의미합니다.

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

USED_GOODS_BOARDUSED_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
+ +> 출처: 프로그래머스 코딩 테스트 연습, https://school.programmers.co.kr/learn/challenges \ No newline at end of file diff --git a/프로그래머스/3/164671. 조회수가 가장 많은 중고거래 게시판의 첨부파일 조회하기/조회수가 가장 많은 중고거래 게시판의 첨부파일 조회하기.sql b/프로그래머스/3/164671. 조회수가 가장 많은 중고거래 게시판의 첨부파일 조회하기/조회수가 가장 많은 중고거래 게시판의 첨부파일 조회하기.sql new file mode 100644 index 0000000..ac8d9fc --- /dev/null +++ b/프로그래머스/3/164671. 조회수가 가장 많은 중고거래 게시판의 첨부파일 조회하기/조회수가 가장 많은 중고거래 게시판의 첨부파일 조회하기.sql @@ -0,0 +1,5 @@ +SELECT CONCAT('/home/grep/src/', UB.BOARD_ID,'/',UF.FILE_ID,UF.FILE_NAME,UF.FILE_EXT) AS FILE_PATH +FROM USED_GOODS_BOARD AS UB +LEFT JOIN USED_GOODS_FILE AS UF ON UB.BOARD_ID = UF.BOARD_ID +WHERE (SELECT MAX(VIEWS) FROM USED_GOODS_BOARD) = UB.VIEWS +ORDER BY UF.FILE_ID DESC \ No newline at end of file