inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

[백문이불여일타] 데이터 분석을 위한 고급 SQL

lead가 아닌 lag로 해도 동일해보이는데요

350

작성자 없음

작성한 질문수 0

0

SELECT DISTINCT lags.num1 AS ConsecutiveNums

FROM

(

SELECT

id,

num AS num1,

lag(num) OVER(ORDER BY id) AS num2,

lag(num,2) OVER(ORDER BY id) AS num3

FROM logs

) AS lags

WHERE lags.num1 = lags.num2 = lags.num3

으로 하면 1과 2가 나오네요 ㅎㅎ ㅠ FROM 절 서브쿼리만 따로 돌려봤을 때에도 num1~3이 모두 같은건 1밖에 없고 테이블을 심플하게 엑셀로 생각해봐도 lead나 lag나 다를게 없어보이는데 최종적으로 돌려볼때는 자꾸 1,2가 모두 나와서요

sql

답변 1

0

지식공유자 J

말씀하신 대로 LEAD 대신 LAG를 쓴 것에는 문제될 부분이 없습니다.

이 쿼리에서 오답이 나오는 이유는 WHERE 절 때문입니다.
지금 작성하신 것처럼 여러 개의 부등호를 동시에 사용해 3개 이상의 값을 비교하는 것은 불가능하므로 아래와 같이 바꿔주셔야 합니다.
WHERE lags.num1 = lags.num2 AND lags.num2 = lags.num3

순위 함수 연습 문제 - 스테디셀러 작가 찾기

0

100

1

문제 내용이 잘못된 것 같습니다.

0

74

2

서브쿼리 질문

0

76

2

[수업질문] 서브쿼리 > null데이터 avg사용 주의

0

85

1

서브쿼리는 언제 작성하는건가요?

0

86

1

안녕하세요 질문드립니다.

0

73

2

Top Earners 문제관련 질문

0

102

2

고급반 cheetsheet

0

167

2

196. Delete Duplicate Emails 좋은 코드 질문

0

148

1

a.id = 1과 b.id=1이 없어도 되는 이유

0

134

0

강의 플랫폼

0

205

3

리트코드 177번 function 풀이중 case when 활용을 위한 서브쿼리 구문을 제출 시 검증에 통과되지 않도록 보강된 듯 하네요

0

214

2

ERD 읽는법에 추가 질문 있어요

0

260

1

lead, lag로 풀이할 시 id 값이 존재하지 않는 경우의 오답

0

369

2

사용자정의함수

0

233

1

이 문제 inner join이 이해가 안됩니다.

0

303

1

평균 함수 사용할 때 주의점과 해결법

0

266

1

196. subquery로 풀 때, 궁금한 점

0

392

2

쿼리성능 질문드립니다.

0

320

1

리트코드 highest department salary 문제

0

265

2

The report 문제 order by부분 질문

0

276

2

리트코드 서브쿼리 문제 질문

0

426

1

DEPARTMENT HIGHEST SALARY 서브쿼리 문제 문의

0

243

1

서브쿼리의 활용사례 및 조인관련질문

0

292

1