개발자 Q&A

개발하다 막혔다면? 여기서 질문하세요! 초보부터 고수까지, 함께 고민하고 해결하는 공간입니다. 누구나 자유롭게 질문하고 답변을 남겨보세요!

2025.06.30 20:25

COUNT(*) 함수에 대한 질문

목록
  • 인증체계장인 1일 전 2025.06.30 20:25
  • 23
    1
안녕하세요 선생님. COUNT(*) 함수에 대해 도움을 요청하고 싶습니다. COUNT(*) 함수는 테이블 내의 행 수를 반환하는 데 사용됩니다. 하지만 COUNT(*) 함수는 NULL 값을 포함하여 행 수를 반환하지 않습니다.

이러한 점을 고려하여 COUNT(*) 함수를 사용했을 때 NULL 값을 포함하여 행을 세고 싶은데 어떻게 해야 하나요? COUNT(*) 함수의 동작 원리를 이해한 후 NULL 값을 포함하여 행을 세는 방법을 알려주세요.

    댓글목록

    profile_image
    나우호스팅  1일 전



    COUNT(*) 함수는 NULL 값을 포함하여 행 수를 반환하지 않습니다.
    이러한 점을 해결하기 위해서는 COUNT(*) 함수 대신 COUNT(column_name) 또는 COUNT(expression) 함수를 사용하면 됩니다.
    COUNT(column_name) 함수는 column_name에 NULL 값을 포함하여 행 수를 반환합니다.
    COUNT(expression) 함수는 expression이 NULL 값을 포함하여 행 수를 반환합니다.
    예를 들어, 다음과 같은 테이블이 있다고 가정해 보겠습니다.

    | id | name | age |
    | --- | --- | --- |
    | 1 | John | 25 |
    | 2 | Jane | NULL |
    | 3 | Joe | 30 |

    COUNT(*) 함수를 사용하면 3이 반환됩니다.
    COUNT(id) 함수를 사용하면 3이 반환됩니다.
    COUNT(name) 함수를 사용하면 3이 반환됩니다.
    COUNT(age) 함수를 사용하면 2가 반환됩니다.
    COUNT(expression) 함수를 사용할 때는 expression이 NULL 값을 포함하여 행 수를 반환합니다.
    예를 들어, COUNT(age IS NOT NULL) 함수를 사용하면 2가 반환됩니다.
    COUNT(age IS NULL) 함수를 사용하면 1이 반환됩니다.
    COUNT(CASE WHEN age IS NOT NULL THEN 1 ELSE 0 END) 함수를 사용하면 2가 반환됩니다.

    2025-06-30 20:26

  • 개발자 Q&A 포인트 정책
      글쓰기
      50P
      댓글
      10P
  • 전체 32,666건 / 5 페이지

검색

게시물 검색