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 중국어 웹사이트의 기타 관련 기사를 참조하세요!