집 >데이터 베이스 >MySQL 튜토리얼 >MySQL에서 날짜 범위를 효율적으로 비교하려면 어떻게 해야 합니까?
MySQL의 효율적인 날짜 범위 비교
이 가이드에서는 대상 범위와 사전 정의된 범위 집합 간의 중복 여부를 확인하는 데 중점을 두고 MySQL에서 날짜 범위를 효율적으로 비교하는 방법을 보여줍니다.
단순한 접근 방식
범위의 중복 여부를 직접 비교하는 대신 비중복 여부를 확인하는 것이 더 효율적인 방법입니다. 이는 논리적 프로세스를 단순화합니다.
중복 범위 이해
사전 정의된 범위가 대상 범위와 관련하여 다음 조건 중 하나를 충족하면 중복이 발생합니다.
겹치지 않는 범위 식별
반대로, 겹치지 않는 범위는 다음 조건을 충족합니다.
겹치는 범위에 대한 SQL 쿼리
대상 범위(periods
, range_start
)와 겹치는 range_end
테이블(@check_period_start
및 @check_period_end
열 포함)에서 모든 행을 식별하려면:
<code class="language-sql">SELECT * FROM periods WHERE NOT (range_start > @check_period_end OR range_end < @check_period_start);</code>
NOT
연산자는 조건을 반전시켜 중복되는 행만 효과적으로 선택합니다.
대체 쿼리: 직접 중복 확인
또는 겹치는 행을 직접 선택하려면:
<code class="language-sql">SELECT * FROM periods WHERE range_start <= @check_period_end AND range_end >= @check_period_start;</code>
이 쿼리는 사전 정의된 범위 시작이 목표 범위 끝보다 이전이거나 같은지, 사전 정의된 범위 끝이 목표 범위 시작보다 이후이거나 같은지 직접 확인합니다. 일부 사람들에게는 이 접근 방식이 약간 더 읽기 쉬울 수도 있습니다.
위 내용은 MySQL에서 날짜 범위를 효율적으로 비교하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!