> 데이터 베이스 > MySQL 튜토리얼 > SQL Server의 Count(*)와 Count(1) 비교: 성능 차이가 있습니까?

SQL Server의 Count(*)와 Count(1) 비교: 성능 차이가 있습니까?

Barbara Streisand
풀어 주다: 2025-01-23 18:22:08
원래의
626명이 탐색했습니다.

Count(*) vs. Count(1) in SQL Server: Is There a Performance Difference?

*SQL Server: Count() 대 Count(1) – 성능 분석**

많은 SQL 사용자가 COUNT(*)COUNT(1)의 성능 차이에 대해 궁금해합니다. 두 함수 모두 행을 계산하지만 실제 성능에 영향을 미치나요?

SQL Server(특히 2005년 이후 버전)에서 대답은 간단합니다. 큰 성능 차이는 없습니다.

Microsoft 설명서에는 COUNT(*)이 테이블의 모든 행(또는 지정된 조건을 충족하는 행)의 개수를 계산한다고 명시되어 있습니다. 결정적으로, COUNT(1)'1'은 null이 아닌 표현식이므로 동일한 결과가 나옵니다.

SQL Server 쿼리 최적화 프로그램은 이러한 동등성을 인식합니다. 두 기능을 동일하게 처리하므로 실행 계획, I/O 작업 및 궁극적으로 성능이 동일해집니다.

다음 예를 고려해보세요.

<code class="language-sql">SELECT COUNT(1) FROM dbo.tab800krows;
SELECT COUNT(1), FKID FROM dbo.tab800krows GROUP BY FKID;

SELECT COUNT(*) FROM dbo.tab800krows;
SELECT COUNT(*), FKID FROM dbo.tab800krows GROUP BY FKID;</code>
로그인 후 복사

이러한 쿼리를 실행하면 동일한 결과가 생성되어 COUNT(*)COUNT(1)의 기능적 동등성이 확인됩니다. 따라서 둘 사이의 선택은 주로 코딩 스타일이나 개인 취향의 문제입니다. SQL Server의 쿼리 성능에는 영향을 미치지 않습니다.

위 내용은 SQL Server의 Count(*)와 Count(1) 비교: 성능 차이가 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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