>데이터 베이스 >MySQL 튜토리얼 >sys.all_columns 제한을 초과하더라도 SQL Server에서 특정 행 수를 효율적으로 선택할 수 있는 방법은 무엇입니까?

sys.all_columns 제한을 초과하더라도 SQL Server에서 특정 행 수를 효율적으로 선택할 수 있는 방법은 무엇입니까?

Barbara Streisand
Barbara Streisand원래의
2024-12-28 16:13:05806검색

How Can I Efficiently Select a Specific Number of Rows in SQL Server, Even Beyond the sys.all_columns Limit?

SQL Server에서 지정된 행 수 선택

SQL Server에서는 ROW_NUMBER() 함수를 사용하여 특정 행 수를 선택할 수 있습니다. 그러나 반환할 수 있는 행 수에는 제한이 있습니다.

Sys.Columns 제한

제공된 초기 쿼리에서는 행을 선택할 특정 테이블을 지정하지 않습니다. sys.all_columns에 대해 이 쿼리를 실행하면 해당 테이블의 총 행 수가 7374개까지만 반환됩니다.

대체 접근 방식

더 많은 수의 행을 선택하려면 , 대체 방법을 사용할 수 있습니다:

숫자 사용 표:

DECLARE @start INT = 1;
DECLARE @end INT = 10;

WITH numbers AS (
    SELECT @start AS number
    UNION ALL
    SELECT number + 1 
    FROM  numbers
    WHERE number < @end
)
SELECT *
FROM numbers
OPTION (MAXRECURSION 0);

숫자 표를 사용하면 무한한 수의 행을 생성할 수 있습니다. 그러나 이 접근 방식은 상대적으로 느릴 수 있습니다.

탈리 테이블을 위한 계단식 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에 대한 추가 성능 비교 및 ​​추가 세부 정보는 응답에 제공된 링크를 참조하세요.

위 내용은 sys.all_columns 제한을 초과하더라도 SQL Server에서 특정 행 수를 효율적으로 선택할 수 있는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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