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

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

Jan 22, 2025 am 12:56 AM

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() 함수를 하위 쿼리로 사용할 수 있습니다.

예:

-- 分页
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
로그인 후 복사

SQL Server 2012: 오프셋 및 가져오기

SQL Server 2012가 도입되면서 OFFSET 및 FETCH 절은 보다 직접적이고 효율적인 페이징 방법을 제공합니다.

예:

SELECT *
FROM TableName
ORDER BY id
OFFSET 10 ROWS FETCH NEXT 10 ROWS ONLY;
로그인 후 복사

이 쿼리는 처음 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으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

Docker에서 MySQL 메모리 사용을 줄입니다 Docker에서 MySQL 메모리 사용을 줄입니다 Mar 04, 2025 pm 03:52 PM

Docker에서 MySQL 메모리 사용을 줄입니다

Alter Table 문을 사용하여 MySQL에서 테이블을 어떻게 변경합니까? Alter Table 문을 사용하여 MySQL에서 테이블을 어떻게 변경합니까? Mar 19, 2025 pm 03:51 PM

Alter Table 문을 사용하여 MySQL에서 테이블을 어떻게 변경합니까?

MySQL의 문제를 해결하는 방법 공유 라이브러리를 열 수 없습니다. MySQL의 문제를 해결하는 방법 공유 라이브러리를 열 수 없습니다. Mar 04, 2025 pm 04:01 PM

MySQL의 문제를 해결하는 방법 공유 라이브러리를 열 수 없습니다.

Linux에서 MySQL을 실행합니다 (Phpmyadmin이있는 Podman 컨테이너가 포함되지 않음) Linux에서 MySQL을 실행합니다 (Phpmyadmin이있는 Podman 컨테이너가 포함되지 않음) Mar 04, 2025 pm 03:54 PM

Linux에서 MySQL을 실행합니다 (Phpmyadmin이있는 Podman 컨테이너가 포함되지 않음)

sqlite 란 무엇입니까? 포괄적 인 개요 sqlite 란 무엇입니까? 포괄적 인 개요 Mar 04, 2025 pm 03:55 PM

sqlite 란 무엇입니까? 포괄적 인 개요

MacOS에서 여러 MySQL 버전을 실행 : 단계별 가이드 MacOS에서 여러 MySQL 버전을 실행 : 단계별 가이드 Mar 04, 2025 pm 03:49 PM

MacOS에서 여러 MySQL 버전을 실행 : 단계별 가이드

인기있는 MySQL GUI 도구는 무엇입니까 (예 : MySQL Workbench, Phpmyadmin)? 인기있는 MySQL GUI 도구는 무엇입니까 (예 : MySQL Workbench, Phpmyadmin)? Mar 21, 2025 pm 06:28 PM

인기있는 MySQL GUI 도구는 무엇입니까 (예 : MySQL Workbench, Phpmyadmin)?

MySQL 연결에 대한 SSL/TLS 암호화를 어떻게 구성합니까? MySQL 연결에 대한 SSL/TLS 암호화를 어떻게 구성합니까? Mar 18, 2025 pm 12:01 PM

MySQL 연결에 대한 SSL/TLS 암호화를 어떻게 구성합니까?

See all articles