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 중국어 웹사이트의 기타 관련 기사를 참조하세요!