>데이터 베이스 >MySQL 튜토리얼 >특히 대규모 데이터 세트를 처리할 때 SQL Server에서 특정 행 범위를 효율적으로 선택할 수 있는 방법은 무엇입니까?

특히 대규모 데이터 세트를 처리할 때 SQL Server에서 특정 행 범위를 효율적으로 선택할 수 있는 방법은 무엇입니까?

Barbara Streisand
Barbara Streisand원래의
2025-01-01 09:07:10885검색

How Can I Efficiently Select a Specific Range of Rows in SQL Server, Especially When Dealing with Large Datasets?

SQL Server에서 행 범위 선택: 행 개수 제한 관리

SQL Server의 일반적인 요구 사항은 특정 행 범위를 선택하는 것입니다. 테이블에서. 이는 각각 고유한 제한 사항과 성능 고려 사항이 있는 çeşitli 메서드를 통해 달성할 수 있습니다.

sys.all_columns의 제한된 행 수

한 가지 기술에는 ROW_NUMBER() 및 지정된 범위 내의 행 목록을 생성하는 CTE입니다. 그러나 이 접근 방식은 대형 테이블, 특히 7374행을 초과하는 범위에 적용할 때 제한 사항에 직면합니다. 이는 기본 sys.all_columns 테이블에 매우 많은 양의 이동이 있기 때문입니다.

행 범위를 생성하는 대체 방법

이 제한을 극복하려면 대체 방법 계단식 CTE를 활용하여 "탈리 테이블"을 생성합니다. 이 접근 방식은 지정된 범위까지의 숫자 목록을 생성합니다. 예는 다음과 같습니다.

DECLARE @Range AS INT = 7374

;WITH E1(N) AS( -- 10 ^ 1 = 10 rows
    SELECT 1 FROM(VALUES (1),(1),(1),(1),(1),(1),(1),(1),(1),(1))t(N)
),
E2(N) AS(SELECT 1 FROM E1 a CROSS JOIN E1 b), -- 10 ^ 2 = 100 rows
E4(N) AS(SELECT 1 FROM E2 a CROSS JOIN E2 b), -- 10 ^ 4 = 10,000 rows
E8(N) AS(SELECT 1 FROM E4 a CROSS JOIN E4 b), -- 10 ^ 8 = 10,000,000 rows
CteTally(N) AS(
    SELECT TOP(@Range) ROW_NUMBER() OVER(ORDER BY(SELECT NULL))
    FROM E8
)
SELECT * FROM CteTally

이 방법은 지정된 @Range까지 집계 테이블을 생성하여 행 범위를 생성하는 보다 효율적인 방법을 제공합니다.

성능 고려 사항

탈리 테이블을 생성하는 다양한 방법의 성능은 특정 요구 사항 및 데이터베이스 환경에 따라 다릅니다. 포괄적인 성능 비교를 보려면 Jeff Moden의 기사 및 기타 연구 조사와 같은 외부 리소스를 참조하세요.

요약

SQL Server에서는 행 범위를 선택하는 것이 일반적입니다. 다양한 기술을 사용하여 작업을 수행할 수 있습니다. 각 접근 방식의 제한 사항과 성능 고려 사항을 이해하면 특정 시나리오에 가장 효율적인 방법을 선택할 수 있습니다. 여기에 제시된 계단식 CTE 접근 방식은 다른 방법에서 발생하는 한계를 극복하여 최대 행 수까지 집계 테이블을 생성하는 안정적이고 확장 가능한 방법을 제공합니다.

위 내용은 특히 대규모 데이터 세트를 처리할 때 SQL Server에서 특정 행 범위를 효율적으로 선택할 수 있는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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