DB/SQL오답노트

[SQL/SQL오답노트]LV3.조건에 맞는 사용자와 총 거래금액 조회하기

2023. 4. 5. 12:13

1.문제

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

 

프로그래머스

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

programmers.co.kr

 

2.정답

SELECT GU.USER_ID
         , GU.NICKNAME
         , GB.TOTAL_SALES
      FROM USED_GOODS_USER GU
INNER JOIN ( SELECT WRITER_ID
                  , SUM(PRICE) AS TOTAL_SALES
               FROM USED_GOODS_BOARD
              WHERE STATUS = 'DONE'
           GROUP BY WRITER_ID
             HAVING SUM(PRICE) >= 700000
           ) GB ON GU.USER_ID = GB.WRITER_ID
ORDER BY TOTAL_SALES

 

3.해설

- USED_GOODS_USER 테이블과 USED_GOODS_BOARD 테이블에서 상태가 DONE고, WRITER_ID 컬럼을 기준으로 GROUP BY를 하는데, PRICE의 총합이 700000 이상인 데이터를 가져와서 USER_ID와 WRITER_ID 컬럼을 기준으로 INNER JOIN을 한다.

- 각 USER_ID, NICKNAME, TOTAL_SALES를 출력하면 되는데, TOTAL_SALES기준으로 오름차순 정렬을 하면 된다.

 

4.내가 문제를 못 푼 이유

-컬럼명을 제대로 뽑아내지 못했다. 별칭 AS는 한번 적용되면 그대로 쓰면 된다. 굳이 반복적으로 별칭이 사용되기 전 문법을 써주지 않아도 된다.

-GROUP BY ~ HAVING절을 제대로 이해 못했다. 여기서 쓰인 집계함수(SUM)의 목적을 이해해야한다. 문제에서는 중고거래 금액이 70만원 이상인 '회원 ID'를 구하고자한다. 그렇다면 금액이 적혀있는 USED_GOODS_BOARD 테이블에서 금액의 총합이 70만원인 데이터를 뽑아오면 되는데, '무엇'의 금액 총합인지 정해줘야한다. '회원ID' 총 거래금액이기 때문에 테이블에서는 회원아이디와 같은 WRITER_ID가 무엇에 해당한다. 그래서 SELECT문에서 집계함수 SUM과 WRITER_ID가 함꼐 쓰였다. 

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

[SQL/SQL오답노트]LV3.대여 횟수가 많은 자동차들의 월별 대여 횟수 구하기  (0) 2023.04.12
[SQL/SQL오답노트]LV4.서울에 위치한 식당 목록 출력하기  (0) 2023.04.06
[SQL/SQL오답노트]LV4.그룹별 조건에 맞는 식당 목록 출력하기  (0) 2023.04.05
[SQL오답노트/프로그래머스]LV2.조건에 부합하는 중고거래 상태 조회하기  (0) 2023.03.10
[SQL오답노트/프로그래머스]LV2.입양 시각 구하기(1)  (0) 2023.03.07
'DB/SQL오답노트' 카테고리의 다른 글
  • [SQL/SQL오답노트]LV3.대여 횟수가 많은 자동차들의 월별 대여 횟수 구하기
  • [SQL/SQL오답노트]LV4.서울에 위치한 식당 목록 출력하기
  • [SQL/SQL오답노트]LV4.그룹별 조건에 맞는 식당 목록 출력하기
  • [SQL오답노트/프로그래머스]LV2.조건에 부합하는 중고거래 상태 조회하기
각시탈코더
각시탈코더
각시탈코더
각시탈코더
각시탈코더
전체
오늘
어제
  • 분류 전체보기 (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)

블로그 메뉴

  • 홈
  • 태그
  • 방명록

공지사항

인기 글

태그

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

최근 댓글

최근 글

hELLO · Designed By 정상우.
각시탈코더
[SQL/SQL오답노트]LV3.조건에 맞는 사용자와 총 거래금액 조회하기
상단으로

티스토리툴바

개인정보

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

단축키

내 블로그

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

블로그 게시글

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

모든 영역

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

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