inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

서브쿼리 해커랭크 문제풀이

해커랭크 Top Earners 질문!

312

김주현

작성한 질문수 7

0

안녕하세요! 해커랭크 Top Earners 문제에 관해 질문드리겠습니다.

 

where 절에 서브쿼리를 사용할 때,

select salary*months as earnings, count(*)

from employee

where salary*months = (select max(salary*months) from employee)

 

위의 코드를 작성했을때 group by 없이는 집계함수를 사용할 수 없다는 오류가 뜨는데,

 

select count(*)

from employee

where salary*months = (select max(salary*months) from employee)

 

select 에 count만 출력했을 때는 문제 없이 코드가 실행됩니다!

count 단독으로 출력할 때는 전체 갯수만 파악하지만 salary*months 까지 같이 출력할 때는 해당 salary*months에 맞게 count를 해야해서 집계함수를 사용해야 하는 걸까요?

어짜피 max값만 가져와서 출력하는데도 group by를 꼭 사용해야 하는걸까요?

 

sql

답변 1

0

지식공유자 J

count 단독으로 출력할 때는 전체 갯수만 파악하지만 salary*months 까지 같이 출력할 때는 해당 salary*months에 맞게 count를 해야해서 집계함수를 사용해야 하는 걸까요?
-> 맞습니다. select 절에 집계함수(count)와 집계함수가 아닌 컬럼이 같이 들어갈 경우, 컬럼을 기준으로 묶은 그룹마다 집계를 하는 것이 됩니다.
group by를 사용하고 싶지 않다면 두번째 쿼리처럼 작성하시면 됩니다.

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

0

88

1

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

0

59

2

서브쿼리 질문

0

61

2

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

0

73

1

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

0

69

1

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

0

66

2

Top Earners 문제관련 질문

0

97

2

고급반 cheetsheet

0

150

2

196. Delete Duplicate Emails 좋은 코드 질문

0

143

1

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

0

127

0

강의 플랫폼

0

199

3

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

0

205

2

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

0

252

1

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

0

360

2

사용자정의함수

0

230

1

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

0

298

1

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

0

261

1

196. subquery로 풀 때, 궁금한 점

0

385

2

쿼리성능 질문드립니다.

0

315

1

리트코드 highest department salary 문제

0

260

2

The report 문제 order by부분 질문

0

271

2

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

0

422

1

DEPARTMENT HIGHEST SALARY 서브쿼리 문제 문의

0

237

1

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

0

287

1