> 데이터 베이스 > MySQL 튜토리얼 > SQL은 어떻게 두 테이블 사이의 겹치는 시간 간격을 효율적으로 식별할 수 있습니까?

SQL은 어떻게 두 테이블 사이의 겹치는 시간 간격을 효율적으로 식별할 수 있습니까?

Mary-Kate Olsen
풀어 주다: 2024-12-31 04:20:09
원래의
258명이 탐색했습니다.

How Can SQL Efficiently Identify Overlapping Time Intervals Between Two Tables?

SQL에서 시간 간격 중복을 효율적으로 식별

문제:

시작 및 종료 시간 열이 있는 두 개의 테이블이 주어지면, 작업은 첫 번째 테이블의 각 행과 시간 간격이 겹치는 두 번째 테이블의 행을 식별하는 것입니다. 조건은 종료 시간이 null인 두 번째 테이블의 행도 고려합니다.

해결책:

SQL Server 2005 구문을 사용하면 다음 WHERE 절이 이 문제를 효과적으로 해결합니다. 문제:

SELECT * 
FROM table1,table2 
WHERE table2.start <= table1.end 
AND (table2.end IS NULL OR table2.end >= table1.start)
로그인 후 복사

설명:

  • table2.start <= table1.end 절은 잠재적인 중복 간격의 시작 시간을 보장합니다. table2는 table1의 현재 간격의 종료 시간 내에 있습니다.
  • 두 번째 조건 table2.end IS NULL OR table2.end >= table1.start, table2의 null 종료 시간을 처리합니다. 종료 시간이 null인 경우 간격을 무기한 연장하는 것으로 간주되어 table1의 후속 간격과 잠재적으로 겹칠 수 있습니다. 또는 종료 시간이 유효한 값이고 table1의 현재 간격의 시작 시간보다 크거나 같으면 중복이 감지됩니다.

위 내용은 SQL은 어떻게 두 테이블 사이의 겹치는 시간 간격을 효율적으로 식별할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿