>데이터 베이스 >MySQL 튜토리얼 >성능 및 총 개수 검색을 고려하여 SQL Server에서 결과의 페이지를 효율적으로 매길 수 있는 방법은 무엇입니까?

성능 및 총 개수 검색을 고려하여 SQL Server에서 결과의 페이지를 효율적으로 매길 수 있는 방법은 무엇입니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2025-01-22 00:56:13853검색

How Can I Efficiently Paginate Results in SQL Server, Considering Performance and Total Count Retrieval?

효율적인 페이징: 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 절이 필요합니다.

참고:

  • OFFSET 및 FETCH를 사용할 때는 ORDER BY가 필요합니다.
  • OFFSET은 FETCH와 함께 사용해야 합니다.
  • 동일 쿼리 표현식에서 TOP는 OFFSET, FETCH와 함께 사용할 수 없습니다.

결론

SQL Server에서 결과의 페이지를 매기는 가장 좋은 방법은 사용되는 특정 버전에 따라 다릅니다. ROW_NUMBER() 메서드는 이전 버전에서도 여전히 가능하지만 SQL Server 2012 이상 버전에서는 OFFSET 및 FETCH가 더 효율적이고 단순화된 솔루션을 제공합니다.

위 내용은 성능 및 총 개수 검색을 고려하여 SQL Server에서 결과의 페이지를 효율적으로 매길 수 있는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.