COUNT(*) 대 COUNT(column_name): 차이점은 무엇이며 각각 언제 사용해야 합니까?

Patricia Arquette
풀어 주다: 2024-11-17 22:49:02
원래의
177명이 탐색했습니다.

COUNT(*) vs. COUNT(column_name): What's the Difference and When Should You Use Each?

COUNT(*)와 COUNT(column_name)의 차이점 이해

SQL 쿼리 작업 시, COUNT(*)와 COUNT(column_name)의 차이점을 이해하는 것이 중요합니다. 정확한 확인을 위해 COUNT(*) 및 COUNT(column_name) 결과.

COUNT(*)

COUNT(*)는 NULL 값이 포함되어 있는지 여부에 관계없이 결과 집합의 모든 행을 계산합니다. 이는 쿼리 기준을 충족하는 모든 행을 고려하므로 가장 포괄적인 개수입니다.

COUNT(column_name)

COUNT(column_name)는 지정된 열이 NULL이 아닙니다. 이 함수는 지정된 열에 누락된 값이 있는 행을 무시합니다.

성능에 미치는 영향

COUNT()는 다음과 같은 경우 COUNT()보다 계산 집약적일 수 있습니다. 테이블에 NULL 값이 많습니다. COUNT(

)는 관계없이 각 행을 확인해야 하므로 이러한 시나리오에서는 성능이 느려질 수 있습니다.

COUNT(*)

COUNT(1)의 대안은 다음과 같습니다. 총 행 수를 반환하는 COUNT(*)의 대안입니다. 그러나 다른 열 값에 관계없이 항상 NULL이 아닌 값으로 평가됩니다.

실험적 데모

결과의 차이를 설명하려면 다음 표를 고려하세요. 쿼리:
CREATE TABLE table1 (x INT NULL);
INSERT INTO table1 (x) VALUES (1), (2), (NULL);
SELECT
    COUNT(*) AS a,
    COUNT(x) AS b,
    COUNT(1) AS c
FROM table1;
로그인 후 복사

결과:

a   b   c
3   2   3
로그인 후 복사

보시다시피 COUNT()는 모든 행을 계산하므로 3을 반환하고, COUNT( x)는 NULL 값 행을 제외하고 2를 반환합니다. COUNT(1)는 COUNT(

)와 구별되지 않으므로 3도 반환합니다.

위 내용은 COUNT(*) 대 COUNT(column_name): 차이점은 무엇이며 각각 언제 사용해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿