집 >데이터 베이스 >MySQL 튜토리얼 >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 함수를 사용하여 시작 날짜에 추가되어 효과적으로 날짜가 증가하는 결과 집합을 생성합니다.
이 방법에는 다음과 같은 장점이 있습니다.
SQL Server 2008 이상의 경우 이 방법은 T-SQL에서 증가하는 날짜 집합을 생성하기 위한 효율적이고 간단한 솔루션을 제공합니다.
위 내용은 T-SQL에서 날짜 시퀀스를 효율적으로 생성하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!