• 카테고리

    질문 & 답변
  • 세부 분야

    데이터 분석

  • 해결 여부

    미해결

challenges_created 가 50일 때

20.08.16 02:12 작성 조회수 124

0

저는 다음과 같이 쿼리를 짰습니다.

challenges_created = 50 일때를 다음과 같이

challenges_created = max(challenges_created)일 때 남겨놓는 것으로 짰는데, 이럴 때 적용이 안 되더라고요.

혹시 왜 안 돼는지 알 수 있을까요?

강의에서는 group by로 한다음 select max(challenges_created)로 해서 적용하는데,

두 가지의 차이는 무엇인가요?

특히, having 에 challenges_created = max(challenges_created)만 조건을 적용하면, Null값들이 나오더라고요.

왜 null값이 나오는지도 궁금합니다ㅠ

SELECT h.hacker_id AS hacker_id

     , h.name AS name

     , ch.tot AS challenges_created

FROM Hackers AS h

LEFT JOIN (SELECT hacker_id, count(hacker_id) AS tot

FROM Challenges

GROUP BY hacker_id

HAVING count(hacker_id) = max(count(hacker_id))) as ch ON ch.hacker_id = h.hacker_id

INNER JOIN (SELECT list.tot AS chall, count(list.tot) AS TOT

FROM (

    SELECT hacker_id, count(hacker_id) AS tot

    FROM Challenges

    GROUP BY hacker_id

) list

GROUP by list.tot

HAVING count(list.tot) = 1 OR list.tot = max(list.tot)) as list ON ch.tot = list.chall

ORDER BY challenges_created DESC, hacker_id ASC

답변 1

답변을 작성해보세요.

0

안녕하세요.

Null 값들이 정확히 어떤 상황에, 어떻게 나오는지 알려주시면 답변 하는데 도움이 될 것 같네요 :)

그리고 코드에 어떤 의도를 가지고 작성한건지 블록마다 주석을 달아주시면 좋겠습니다.