집 >데이터 베이스 >MySQL 튜토리얼 >주어진 범위 내에서 날짜 시퀀스를 효율적으로 생성하는 방법은 무엇입니까?
지정된 범위 내에서 날짜 시퀀스 생성
질문:
지정된 범위의 모든 날짜를 효율적으로 가져와 커서에 저장하는 방법은 무엇입니까?
해결책:
날짜표 사용
날짜 테이블은 날짜를 검색하는 간단하고 직접적인 방법을 제공합니다. 가능한 경우 다음과 같은 쿼리를 사용하세요.
<code class="language-sql">DECLARE @MinDate DATE = '20140101', @MaxDate DATE = '20140106'; SELECT Date FROM dbo.Calendar WHERE Date >= @MinDate AND Date < @MaxDate;</code>
동적으로 시퀀스 생성
날짜 테이블이 없는 경우 다음 쿼리를 사용하여 날짜 순서를 생성할 수 있습니다.
<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>
커서 사용 자제
성능을 향상하려면 커서 대신 컬렉션 기반 대안을 사용하는 것이 좋습니다. 예를 들어 특정 품목 및 날짜의 수량을 검색하려면 다음을 수행하세요.
<code class="language-sql">DECLARE @ToDate DATE = '20140428'; SELECT TOP 1 date, it_cd, qty FROM T WHERE it_cd = 'i-1' AND Date <= @ToDate ORDER BY Date DESC;</code>
위 내용은 주어진 범위 내에서 날짜 시퀀스를 효율적으로 생성하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!