DB/SQL오답노트

[SQL/SQL오답노트]LV4.서울에 위치한 식당 목록 출력하기

2023. 4. 6. 12:12
목차
  1. 1.문제
  2. 2.정답
  3. 3.내가 정답을 못 적은 이유

1.문제

https://school.programmers.co.kr/learn/courses/30/lessons/131118

 

프로그래머스

코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.

programmers.co.kr

 

2.정답

SELECT RI.REST_ID, RI.REST_NAME, RI.FOOD_TYPE, RI.FAVORITES, RI.ADDRESS, RR.SCORE
FROM REST_INFO RI
INNER JOIN (
    SELECT REST_ID,ROUND(AVG(REVIEW_SCORE), 2) AS SCORE
    FROM REST_REVIEW
    GROUP BY REST_ID) RR
ON RI.REST_ID = RR.REST_ID
WHERE RI.ADDRESS LIKE '서울%'
ORDER BY RR.SCORE DESC, RI.FAVORITES DESC

 

3.내가 정답을 못 적은 이유

- 문제 전략을 제대로 세우지 못했다. 조인 테이블의 범위를 생각치 못했다.

문제에서 제시된 조건은 크게 세 가지다.

 

①식당은 서울에 위치한다.

②리뷰 평균점수는 소수점 셋째자리에서 반올림한다.

③평균점수를 기준으로 내림차순으로 정렬, 즐겨 찾기 수를 기준으로 내림차순 정렬

 

이런 조건을 충족시키기 위해선 조인을 해야한다. 조인을 해야한다는 생각을 하는 건 어렵지 않았지만, 문제 요구에 맞는 정확한 쿼리를 작성하지 못했다. 세 조건중에 ②조건에 맞춰 조인 대상을 서브쿼리로 작성하면 문제에서 요구하는 테이블을 만드는데에 적합해진다. 이 조건을 만족시켜 쿼리문을 작성한다면 나머지 ①,③ 조건의 쿼리문을 짜는 건 시간문제다. '조인 테이블을 어떻게 문제에 적합한 형태로 만들것인가'가 이 문제에 핵심이라고 볼 수 있다.

 

 

'DB > SQL오답노트' 카테고리의 다른 글

[SQL/SQL오답노트]LV4.우유와 요거트가 담긴 장바구니  (0) 2023.04.13
[SQL/SQL오답노트]LV3.대여 횟수가 많은 자동차들의 월별 대여 횟수 구하기  (0) 2023.04.12
[SQL/SQL오답노트]LV3.조건에 맞는 사용자와 총 거래금액 조회하기  (0) 2023.04.05
[SQL/SQL오답노트]LV4.그룹별 조건에 맞는 식당 목록 출력하기  (0) 2023.04.05
[SQL오답노트/프로그래머스]LV2.조건에 부합하는 중고거래 상태 조회하기  (0) 2023.03.10
  1. 1.문제
  2. 2.정답
  3. 3.내가 정답을 못 적은 이유
'DB/SQL오답노트' 카테고리의 다른 글
  • [SQL/SQL오답노트]LV4.우유와 요거트가 담긴 장바구니
  • [SQL/SQL오답노트]LV3.대여 횟수가 많은 자동차들의 월별 대여 횟수 구하기
  • [SQL/SQL오답노트]LV3.조건에 맞는 사용자와 총 거래금액 조회하기
  • [SQL/SQL오답노트]LV4.그룹별 조건에 맞는 식당 목록 출력하기
각시탈코더
각시탈코더
각시탈코더
각시탈코더
각시탈코더
전체
오늘
어제
  • 분류 전체보기 (203)
    • java (46)
      • 객체지향 (20)
      • 기본문법 (8)
      • 자바의 정석 연습문제 오답노트 (9)
      • 백준 알고리즘 (9)
    • Spring (17)
      • SpringMVC (8)
      • Spring DI와 AOP (5)
      • REST API와 Ajax (1)
      • Spring 프로젝트 (1)
      • Spring Security (0)
    • DB (47)
      • Oracle (15)
      • SQL오답노트 (25)
      • 튜닝 (0)
      • ERD (1)
      • DB 모델링 (5)
    • Servlet & JSP (3)
    • JDBC (2)
      • 기본 (1)
      • 스프링JDBC (1)
    • MyBatis (2)
    • JavaScript (2)
      • 코딩애플 (0)
      • 문법 (1)
    • React (0)
      • 코딩애플 (0)
    • HTML (0)
      • 모던 웹을 위한 HTML5+CSS3 바이블 (0)
    • CSS (0)
      • 모던 웹을 위한 HTML5+CSS3 바이블 (0)
    • Linux (0)
    • Git & GitHub (2)
      • Git (1)
    • CS (19)
      • 네트워크 (6)
      • HTTP (7)
      • 컴퓨터구조 (0)
      • 자료구조와 알고리즘 (2)
      • 기타 (4)
    • 개발설정 (2)
    • 기술면접 (0)
      • JAVA (0)
      • Spring (0)
      • DB (0)
      • 네트워크 (0)
      • 공통 (0)
    • 프로젝트 (2)
      • 게시판만들기 (2)
    • 기혁씨의 삽질표류기 (28)
    • 참고자료 (2)
      • 국비수업 (0)
      • 당당 프로젝트 (1)
    • 뉴렉처 (17)
      • 자바 (11)
      • 자바스크립트 (3)
      • 키워드 (0)
      • 숙제 (0)
      • CSS (0)
      • DB (3)
      • 서블릿 (0)
      • 스프링 (0)
      • DOM (0)
    • 내가 만든 학습그림 (3)

블로그 메뉴

  • 홈
  • 태그
  • 방명록

공지사항

인기 글

태그

  • 연습문제
  • 알고리즘
  • It
  • 모두의네트워크
  • 배열
  • 자바의정석
  • 오라클
  • 객체지향
  • 네트워크
  • 자바
  • 쿼리
  • 코딩
  • 개발자
  • 오류
  • 백엔드
  • 뉴렉처
  • 에러
  • 서브쿼리
  • 국비수업
  • 자바의정석기초편
  • db
  • 웹프로그래밍
  • SQL
  • spring
  • 백준
  • Java
  • Oracle
  • 공부
  • 스프링
  • 프로그래머스

최근 댓글

최근 글

hELLO · Designed By 정상우.
각시탈코더
[SQL/SQL오답노트]LV4.서울에 위치한 식당 목록 출력하기
상단으로

티스토리툴바

개인정보

  • 티스토리 홈
  • 포럼
  • 로그인

단축키

내 블로그

내 블로그 - 관리자 홈 전환
Q
Q
새 글 쓰기
W
W

블로그 게시글

글 수정 (권한 있는 경우)
E
E
댓글 영역으로 이동
C
C

모든 영역

이 페이지의 URL 복사
S
S
맨 위로 이동
T
T
티스토리 홈 이동
H
H
단축키 안내
Shift + /
⇧ + /

* 단축키는 한글/영문 대소문자로 이용 가능하며, 티스토리 기본 도메인에서만 동작합니다.