>데이터 베이스 >MySQL 튜토리얼 >T-SQL에서 날짜 시퀀스를 효율적으로 생성하는 방법은 무엇입니까?

T-SQL에서 날짜 시퀀스를 효율적으로 생성하는 방법은 무엇입니까?

Barbara Streisand
Barbara Streisand원래의
2025-01-11 20:08:43668검색

How to Efficiently Generate a Sequence of Dates in T-SQL?

T-SQL에서 증분 날짜 결과 집합 생성

SQL Server에서 지정된 시작 날짜와 종료 날짜 사이에 설정된 날짜를 생성하려면 효율적이고 최적화된 솔루션이 필요합니다. 일반적인 접근 방식은 WHILE 루프를 사용하여 종료 날짜에 도달할 때까지 시작 날짜에 하루를 점진적으로 추가하는 것입니다.

단, 기간이 2047일 이내인 경우에는 다른 방법을 사용할 수 있습니다. 다음 T-SQL 쿼리는 spt_values ​​시스템 테이블을 사용합니다.

<code class="language-sql">declare @dt datetime, @dtEnd datetime
set @dt = getdate()
set @dtEnd = dateadd(day, 100, @dt)

select dateadd(day, number, @dt)
from (select number from master.dbo.spt_values
where [type] = 'P'
) n
where dateadd(day, number, @dt) < @dtEnd</code>

이 쿼리는 0부터 2047까지의 숫자 범위를 포함하는 spt_values ​​테이블을 활용합니다. 'P' 유형을 필터링하면 일련의 연속된 숫자를 얻을 수 있습니다. 각 숫자는 dateadd 함수를 사용하여 시작 날짜에 추가되어 효과적으로 날짜가 증가하는 결과 집합을 생성합니다.

이 방법에는 다음과 같은 장점이 있습니다.

  • 단순성: 루프나 복잡한 계산이 필요하지 않습니다.
  • 효율성: 쿼리는 시스템 테이블을 사용하여 사용자 정의 테이블과 관련된 오버헤드를 방지합니다.
  • 확장성: 2047일 제한 내에서 더 큰 날짜 범위를 처리할 수 있습니다.

SQL Server 2008 이상의 경우 이 방법은 T-SQL에서 증가하는 날짜 집합을 생성하기 위한 효율적이고 간단한 솔루션을 제공합니다.

위 내용은 T-SQL에서 날짜 시퀀스를 효율적으로 생성하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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