-
[코딩테스트] 프로그래머스 - 서울에 위치한 식당 목록 출력하기(MySQL, Level4)코딩테스트/프로그래머스 2022. 12. 14. 21:26728x90
안녕하세요.
정말 날씨가 춥네요~
오늘은 지하철에 낑겨앉아 조금 멘탈이 흔들렸지만 그래도 무난하게 풀어낸 문제입니다.
그럼 바로 문제 만나보시죠~
https://school.programmers.co.kr/learn/courses/30/lessons/131118
프로그래머스
코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.
programmers.co.kr
이번에는 제가 작성한 쿼리문입니다.
-- 코드를 입력하세요 SELECT ri.rest_id, ri.rest_name, ri.food_type, ri.favorites, ri.address, round(avg(rr.review_score),2) as score from rest_info as ri join rest_review as rr on ri.rest_id=rr.rest_id where ri.address like '서울%' group by ri.rest_id order by score desc, ri.favorites desc
평소에 비하면 내용이 짧죠?
이제 문제를 한 번 들여다 보면서 하나씩 보겠습니다.
① 테이블에서 서울에 위치한 식당 ==> 조건문을 통해서 주소가 '서울'인 곳만 걸러내기
② 식당 ID, 식당 이름, 음식 종류, 즐겨찾기 수, 주소, 리뷰 평균 점수 ==>
- REST INFO Table에 식당 ID, 식당 이름, 음식 종류, 즐겨찾기 수, 주소
- REST REVIEW Table에 리뷰 점수
데이터가 있습니다. 즉, 우리는 두 테이블을 JOIN해야되는 된다는 점을 알 수 있습니다.
③ 리뷰 평균점수(소수점 세 번째 자리에서 반올림) ==> 우리는 리뷰 점수밖에 주어지지 않았습니다.
- 평균을 구하는 방법은 avg(data)
- 소숫점 세 번째 자리에서 반올림 하는 방법 round(data,2)
- 즉 round(avg(data),2)이렇게 하면 평균 리뷰점수의 반올림이 되겠습니다.
④ 다음은 맨 처음에서 언급한 '식당들의' 라는 문구입니다. 그렇다는건 식당별로 보고싶다는 뜻이겠죠? 그렇기에 식당별로 group by를 해야된다는 것을 알아채시면 되겠습니다.
⑤ 마지막으로는 order by를 통해 평균점수 기준 내림차순, 즐쳐찾기수를 기준으로 내림차순 정렬해주시면 되겠습니다.
오늘 쿼리문제풀이는 여기서 마무리하겠습니다.
감사합니다. :D
오늘도 빠샤! 💪
'코딩테스트 > 프로그래머스' 카테고리의 다른 글
[코딩테스트] 프로그래머스 - 카테고리 별 도서 판매량 집계하기(MySQL, Level3) (0) 2022.12.21 [코딩테스트] 프로그래머스 - 취소되지 않은 진료 예약 조회하기(MySQL, Level4) (0) 2022.12.16 [코딩테스트] 프로그래머스 - 년, 월, 성별 별 상품 구매 회원 수 구하기(MySQL, Level4) (0) 2022.12.14 [코딩테스트] 프로그래머스 - 불량 사용자(Java, Level3) (1) 2022.12.12 [코딩테스트] 프로그래머스 - 헤비 유저가 소유한 장소(MySQL, Level3) (0) 2022.12.10