>데이터 베이스 >MySQL 튜토리얼 >MySQL에서 날짜 범위를 효율적으로 비교하려면 어떻게 해야 합니까?

MySQL에서 날짜 범위를 효율적으로 비교하려면 어떻게 해야 합니까?

DDD
DDD원래의
2025-01-18 08:21:09928검색

How Can I Efficiently Compare Date Ranges in 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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