SQL Server에서 두 날짜 사이의 모든 날짜를 가져오는 방법
SQL Server에서는 지정된 날짜 범위 내의 모든 날짜를 가져오는 것이 데이터 분석, 날짜 처리, 기록 저장 등의 작업에 유용합니다. 이 기사에서는 주어진 두 날짜 사이의 연속된 날짜 시퀀스를 효율적으로 얻는 몇 가지 방법을 소개합니다.
재귀 공통 테이블 표현식(CTE) 사용
한 가지 방법은 재귀적 CTE를 사용하는 것입니다. 예시는 다음과 같습니다.
<code class="language-sql">;with GetDates As ( select DATEADD(day,1,@maxDate) as TheDate UNION ALL select DATEADD(day,1, TheDate) from GetDates where TheDate < @minDate ) select TheDate from GetDates</code>
그러나 이 CTE는 날짜 선택에 작동하지만 결과를 커서에 저장하려고 할 때 컴파일 오류로 인해 어려워집니다.
대체 방법
효율성을 높이고 운영을 단순화하려면 다음 대안을 고려하십시오.
1. 날짜표를 활용하세요
날짜 테이블을 미리 만들어 놓으면 쿼리가 매우 간단해집니다.
<code class="language-sql">DECLARE @MinDate DATE = '20140101', @MaxDate DATE = '20140106'; SELECT Date FROM dbo.Calendar WHERE Date >= @MinDate AND Date <= @MaxDate;</code>
2. 날짜 테이블 없이 날짜 시퀀스 생성
날짜 테이블이 없는 경우 다음 기술을 사용하여 날짜 시퀀스를 동적으로 생성할 수 있습니다.
<code class="language-sql">DECLARE @MinDate DATE = '20140101', @MaxDate DATE = '20140106'; SELECT TOP (DATEDIFF(DAY, @MinDate, @MaxDate) + 1) Date = DATEADD(DAY, ROW_NUMBER() OVER(ORDER BY a.object_id) - 1, @MinDate) FROM sys.all_objects a CROSS JOIN sys.all_objects b;</code>
3. 날짜 반복에 커서 사용을 피하세요
일반적으로 날짜 반복에 커서를 사용하지 않는 것이 좋습니다. 컬렉션 기반 접근 방식은 일반적으로 더 효율적이고 확장 가능합니다. 예를 들어 특정 날짜의 수량을 검색하려면 다음 쿼리를 사용할 수 있습니다.
<code class="language-sql">SELECT TOP 1 date, it_cd, qty FROM T WHERE it_cd = 'i-1' AND Date = '20140101';</code>
커서 사용을 피하고 이러한 대체 기술을 활용하면 SQL Server에서 지정된 범위 내의 모든 날짜를 효율적으로 검색할 수 있습니다.
위 내용은 SQL Server에서 두 날짜 사이의 모든 날짜를 효율적으로 검색하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!