SQL Server에서 행 선택
제공된 쿼리는 sys. 열 테이블. 이러한 제한을 극복하기 위한 보다 효율적인 접근 방식은 계단식 CTE를 사용하여 "탈리 테이블" 또는 "숫자 테이블"을 생성하는 것입니다.
다음은 계단식 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
이 접근 방식은 읽기가 전혀 발생하지 않고 매우 많은 수의 행으로 확장되므로 매우 효율적입니다. Tally Tables에 대한 성능 비교 및 자세한 내용은 응답에 제공된 링크 리소스를 참조하세요.
위 내용은 SQL Server에서 많은 수의 행을 효율적으로 선택하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!