집 >데이터 베이스 >MySQL 튜토리얼 >성능 및 총 개수 검색을 고려하여 SQL Server에서 결과의 페이지를 효율적으로 매길 수 있는 방법은 무엇입니까?
효율적인 페이징: SQL Server의 성능 및 전체 검색
데이터베이스 관리의 세계에서는 대규모 데이터 세트를 처리하고 사용자 친화적인 탐색 환경을 제공하기 위해 효율적인 페이징이 매우 중요합니다. 이 문서에서는 성능 및 검색된 총 결과 수를 고려하여 Microsoft SQL Server 2000~2012 버전의 결과 페이징에 대한 모범 사례를 살펴봅니다.
SQL Server 2000-2008: 행 번호 및 COUNT
이전 버전의 SQL Server에서는 ROW_NUMBER() 함수를 사용하여 테이블의 각 행에 일련 번호를 할당하는 것이 일반적인 접근 방식이었습니다. 그런 다음 이 일련 번호를 사용하여 원하는 페이지 번호와 페이지 크기를 기준으로 결과를 필터링할 수 있습니다. 총 개수를 검색하려면 COUNT() 함수를 하위 쿼리로 사용할 수 있습니다.
예:
<code class="language-sql">-- 分页 SELECT * FROM ( SELECT ROW_NUMBER() OVER (ORDER BY id) AS RowNum, * FROM TableName ) AS PaginatedTable WHERE RowNum BETWEEN ((@Page - 1) * @PageSize + 1) AND (@Page * @PageSize) -- 总数 SELECT COUNT(*) AS TotalCount FROM TableName</code>
SQL Server 2012: 오프셋 및 가져오기
SQL Server 2012가 도입되면서 OFFSET 및 FETCH 절은 보다 직접적이고 효율적인 페이징 방법을 제공합니다.
예:
<code class="language-sql">SELECT * FROM TableName ORDER BY id OFFSET 10 ROWS FETCH NEXT 10 ROWS ONLY;</code>
이 쿼리는 처음 10개 행(OFFSET 10 ROWS)을 건너뛰고 다음 10개 행을 검색합니다(FETCH NEXT 10 ROWS ONLY). OFFSET 및 FETCH가 올바르게 작동하려면 ORDER BY 절이 필요합니다.
참고:
결론
SQL Server에서 결과의 페이지를 매기는 가장 좋은 방법은 사용되는 특정 버전에 따라 다릅니다. ROW_NUMBER() 메서드는 이전 버전에서도 여전히 가능하지만 SQL Server 2012 이상 버전에서는 OFFSET 및 FETCH가 더 효율적이고 단순화된 솔루션을 제공합니다.
위 내용은 성능 및 총 개수 검색을 고려하여 SQL Server에서 결과의 페이지를 효율적으로 매길 수 있는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!