>데이터 베이스 >MySQL 튜토리얼 >MySQL에서 겹치는 날짜 범위를 감지하는 방법은 무엇입니까?

MySQL에서 겹치는 날짜 범위를 감지하는 방법은 무엇입니까?

DDD
DDD원래의
2024-12-13 15:28:11850검색

How to Detect Overlapping Date Ranges in MySQL?

MySQL에서 겹치는 날짜 범위 확인

주어진 테이블 내에서 충돌하는 날짜 범위를 확인하려면 다음을 사용하는 맞춤형 쿼리를 고려하십시오. 기준:

WHERE new_start < existing_end AND new_end > existing_start

여기서:

  • new_start 및 new_end는 삽입할 새 세션의 날짜 범위를 나타냅니다.
  • existing_start 및 기존_end는 다음의 날짜 범위를 나타냅니다. 기존 세션

이 쿼리는 제안된 세션과 교차하는 날짜 범위를 효과적으로 식별합니다. 새 세션은 원래 쿼리에 비해 더 세련된 결과를 제공합니다.

쿼리의 업데이트된 버전은 다음과 같습니다.

SELECT *
FROM session
WHERE "2010-01-05" < end_date AND "2010-01-25" > start_date;

이 쿼리는 겹치지 않는 세션을 생략하고 충돌하는 세션만 반환합니다.

+----+------------+------------+
| id | start_date | end_date   |
+----+------------+------------+
|  2 | 2010-01-20 | 2010-01-30 |
+----+------------+------------+

수정된 쿼리를 사용하면 겹치는 세션만 식별되어 충돌 감지에 대한 보다 정확한 결과를 제공합니다.

위 내용은 MySQL에서 겹치는 날짜 범위를 감지하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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