inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

SQL 코딩테스트를 위한 첫 걸음

concat, group_concat

LEETCODE - Sales Analysis 3 코드 질문드립니다.

해결된 질문

284

zuuzuubin

작성한 질문수 1

1

안녕하세요, 젬마님 강의 잘 듣고 있는 수강생입니다. 혹시 수업에서 다루지 않은 leetcode 문제도 질문 받아주실지 잘 모르겠지만 한 번 올려 봅니다...!

Sales Analysis 3 문제의 답을 아래와 같이 적었는데 계속 오류가 납니다. 답변 주시면 감사하겠습니다.

 

SELECT P.PRODUCT_ID, P.PRODUCT_NAME
FROM PRODUCT P
INNER JOIN (
    SELECT *
    FROM SALES
    WHERE PRODUCT_ID NOT IN (
        SELECT PRODUCT_ID
        FROM SALES
        WHERE SALE_DATE < '2019-01-01'
        OR SALE_DATE > '2019-03-31'
    ) 
) N
ON P.PRODUCT_ID = N.PRODUCT_ID;

sql mysql 코딩-테스트

답변 1

0

Gemma

안녕하세요 zuuzuubin 님

꼭 제 강의 아니더라도 SQL 문제 질문은 늘 환영입니다!:)

아래 풀이 보시고 이해 안가시면 재질문 부탁드립니다.

문제: https://leetcode.com/problems/sales-analysis-iii/description/ 

 

풀이에서 DISTINCT 하나만 놓치신거였네요!

Sales 테이블에 ‘This table can have duplicate rows’ 이렇게 써있는데요.

그래서 Sales 테이블에 동일한 product_id가 여러 개 포함될 수 있습니다.

 

풀이1: 

동일한 product_id가 여러 개 있는 Sales 테이블과 Product 테이블이 inner join 하면서, 최종 결과물에 중복된 product_id가 존재할 것입니다. 그래서 최종 바깥쪽 select문에 DISTINCT를 추가하셔도 됩니다.

 

SELECT DISTINCT P.PRODUCT_ID,
P.PRODUCT_NAME
FROM PRODUCT P
INNER JOIN (
    SELECT *
    FROM SALES
    WHERE PRODUCT_ID NOT IN (
        SELECT PRODUCT_ID
        FROM SALES
        WHERE SALE_DATE < '2019-01-01'
        OR SALE_DATE > '2019-03-31'
    ) 
) N
ON P.PRODUCT_ID = N.PRODUCT_ID;

 

풀이2: 

join하는 temp 테이블에서 product_id가 하나만 나오게끔, 미리 DISTINCT product_id를 처리해주셔도 됩니다. 그러면 join을 하더라도 product_id는 최종 결과물에서 하나씩만 나올 것입니다.

SELECT P.PRODUCT_ID,
P.PRODUCT_NAME
FROM PRODUCT P
INNER JOIN (
    SELECT DISTINCT PRODUCT_ID
    FROM SALES
    WHERE PRODUCT_ID NOT IN (
        SELECT PRODUCT_ID
        FROM SALES
        WHERE SALE_DATE < '2019-01-01'
        OR SALE_DATE > '2019-03-31'
    ) 
) N
ON P.PRODUCT_ID = N.PRODUCT_ID;

리뷰를 가장 많이 작성한 회원들 조회

0

6

1

회사 내 AI 툴 사용에 대한 질문

0

16

1

일대일 fk 위치

0

21

1

GROUP BY, HAVING 실습 1번문제

1

19

2

4 - A

0

24

2

코딩 테스트 All-in-One(Java)' 강의 노션 교재 권한문의

0

19

1

수업에서 사용하는 툴 질문드려요

0

28

2

태어난김에 세계일주 시간 초과

0

19

1

2강에 파일 어디있을까여,,

0

20

2

커리큘럼 중 정렬 관련 질문

0

18

1

문제 링크 변경

0

61

2

SQL 파일 다운로드

0

70

2

workbench 테이블 생성

0

280

2

sql 코딩 테스트에서 index 생성 가능 여부

1

287

2

cross join, full join강의 / leetcode 1280번 문제 질문드립니다

1

304

1

not In강의 / leetcode 1978 질문 드립니다

2

204

1

[The Latest Login in 2020] datetime 계산 관련

1

253

1

[Average Selling Price] 문제 테스트케이스 실패

1

285

3

서브쿼리 질문

1

353

1

EASY INNER JOIN 관련 average-selling-price 연습문제

1

286

1

INNER JOIN 강의 질문

1

331

2

문제 주소 링크

1

303

2

work bench 설치관련 문의

1

283

2

깃헙 데스크탑, MYSQL 워크벤치 연동

2

868

3