>데이터 베이스 >MySQL 튜토리얼 >SQL Server에서 두 날짜 사이의 모든 날짜를 효율적으로 검색하는 방법은 무엇입니까?

SQL Server에서 두 날짜 사이의 모든 날짜를 효율적으로 검색하는 방법은 무엇입니까?

Barbara Streisand
Barbara Streisand원래의
2025-01-12 10:13:43721검색

How to Efficiently Retrieve All Dates Between Two Dates in SQL Server?

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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