>데이터 베이스 >MySQL 튜토리얼 >T-SQL에서 날짜 범위 결과 집합을 효율적으로 생성하려면 어떻게 해야 합니까?

T-SQL에서 날짜 범위 결과 집합을 효율적으로 생성하려면 어떻게 해야 합니까?

Susan Sarandon
Susan Sarandon원래의
2025-01-11 20:16:48280검색

How Can I Efficiently Generate a Date Range Resultset in T-SQL?

T-SQL에서 날짜 시리즈 생성

이 문서에서는 T-SQL을 사용하여 지정된 범위 내에서 일련의 날짜가 포함된 결과 집합을 생성하는 효율적인 기술을 보여줍니다. 최적화된 접근 방식에 중점을 두고 이 날짜 계열을 생성하는 방법을 살펴보겠습니다.

기간 정의

시작일과 종료일을 설정해 보겠습니다.

<code class="language-sql">DECLARE @StartDate datetime = 'Mar 1 2009', @EndDate datetime = 'Aug 1 2009'</code>

루프 기반 접근 방식(덜 효율적임)

간단하지만 덜 효율적인 방법은 WHILE 루프를 활용합니다.

<code class="language-sql">DECLARE @currentDate datetime
SET @currentDate = @StartDate
WHILE @currentDate <= @EndDate
BEGIN
    SELECT @currentDate
    SET @currentDate = DATEADD(day, 1, @currentDate)
END</code>

이 반복적 접근 방식은 효과가 있지만 기간이 길면 속도가 느려질 수 있습니다.

spt_values을 사용한 최적화된 접근 방식(SQL Server 2005 이상)

특히 더 넓은 날짜 범위에서 성능을 향상하려면 spt_values 시스템 테이블을 활용하세요(SQL Server 2005 이상 버전에서 사용 가능).

<code class="language-sql">DECLARE @StartDate datetime, @EndDate datetime;
SET @StartDate = GETDATE();
SET @EndDate = DATEADD(day, 100, @StartDate);

SELECT DATEADD(day, number, @StartDate) AS DateValue
FROM master..spt_values
WHERE type = 'P'
  AND DATEADD(day, number, @StartDate) <= @EndDate;</code>

이 쿼리는 시작 날짜에 spt_values의 일련 번호를 추가하고 지정된 범위 내의 날짜만 포함하도록 필터링하여 날짜 계열을 효율적으로 생성합니다. 이 방법은 더 큰 데이터 세트에 대한 루프 기반 접근 방식보다 훨씬 빠릅니다. master..spt_values 테이블은 쉽게 사용할 수 있는 일련의 숫자를 제공하므로 이 작업에 이상적입니다.

위 내용은 T-SQL에서 날짜 범위 결과 집합을 효율적으로 생성하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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