집 >데이터 베이스 >MySQL 튜토리얼 >SQL Server 결과를 효율적으로 페이지 매김하고 총 개수를 얻으려면 어떻게 해야 합니까?
SQL Server 효율적인 페이징 및 전체 획득
SQL Server에서 페이징 검색을 사용하면 모든 데이터를 한 번에 가져오는 대신 일괄적으로 데이터를 가져올 수 있습니다. 이는 특히 대규모 데이터 세트로 작업할 때 성능을 크게 향상시킬 수 있습니다.
SQL Server 2012 이상 모범 사례
SQL Server 2012 버전에서는 더 간단한 페이징 방법이 도입되었습니다. OFFSET
및 FETCH
절은 총 개수를 가져오면서 필요한 결과 개수를 검색하는 간단한 방법을 제공합니다.
예를 들어 다음 10개 데이터 행을 가져오는 동시에 총계를 가져오려면 다음을 수행하세요.
<code class="language-sql">-- 获取带有行号的接下来的10行 SELECT *, ROW_NUMBER() OVER (ORDER BY id) AS RowNum FROM TableName; -- 统计总行数 SELECT COUNT(*) AS TotalCount FROM TableName;</code>
OFFSET 및 FETCH를 사용한 페이징
SQL Server 2012부터 OFFSET
및 FETCH
절을 사용하여 검색할 행을 명시적으로 지정할 수 있습니다.
<code class="language-sql">SELECT * FROM TableName ORDER BY id OFFSET 10 ROWS FETCH NEXT 10 ROWS ONLY;</code>
OFFSET 및 FETCH에 대한 주요 참고사항
OFFSET
, FETCH
사용 시에는 ORDER BY
절이 필수입니다. OFFSET
과 FETCH
는 반드시 함께 사용해야 하며, OFFSET
은 단독으로 사용할 수 없습니다. OFFSET
및 FETCH
은 동일한 쿼리에서 TOP
과 결합할 수 없습니다. 위 내용은 SQL Server 결과를 효율적으로 페이지 매김하고 총 개수를 얻으려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!