>데이터 베이스 >MySQL 튜토리얼 >SQL Server에서 특정 행 수를 효율적으로 선택하는 방법은 무엇입니까?

SQL Server에서 특정 행 수를 효율적으로 선택하는 방법은 무엇입니까?

Susan Sarandon
Susan Sarandon원래의
2024-12-29 18:46:11441검색

How to Efficiently Select a Specific Number of Rows in SQL Server?

SQL Server에서 N 행 선택

쿼리 1:

DECLARE @Range AS INT = 10

;WITH CTE AS(
    SELECT TOP (@Range) Duration = ROW_NUMBER() OVER(ORDER BY OBJECT_ID)
    FROM sys.all_columns
    ORDER BY [Object_id]
)
SELECT Duration from CTE

설명:

이 쿼리는 sys.all_columns 테이블. 따라서 @Range를 10,000으로 설정하면 sys.all_columns의 행 수인 7,374개 행만 반환됩니다.

쿼리 2:

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)을 사용하여 @start에서 @end까지 숫자 테이블을 생성합니다. 행 수가 무제한인 테이블을 생성할 때 반복 오류를 방지하려면 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

계단식 CTE의 장점:

  • 다른 테이블에서 읽지 않고 행을 생성합니다.
  • 쉽게 확장하여 수십억 개의 테이블을 생성할 수 있습니다. 행.
  • 다른 방법과의 성능 비교에서 좋은 성능을 발휘합니다.

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

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