집 >데이터 베이스 >MySQL 튜토리얼 >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 중국어 웹사이트의 기타 관련 기사를 참조하세요!