使用sql判断两段时间是否重叠
-
- [1. 时间点重叠判断](#1. 时间点重叠判断)
-
- a)时间重叠有以下4种情况时间重叠有以下4种情况)
- a)时间不重叠只有以下2种情况时间不重叠只有以下2种情况)
- [判断条件, 不重叠的判断](#判断条件, 不重叠的判断)
- [判断条件, 重叠的判断](#判断条件, 重叠的判断)
假设现在有时间 [startTime, endTime], 数据库存在字段 sql_start_time 和 sql_end_time, 分别表示要判断的时间段和数据库的时间段, 分析是否2个时间段是否存在重叠部分
1. 时间点重叠判断
a)时间重叠有以下4种情况
红色代表要判断的时间段 [startTime, endTime], 蓝色代表数据库时间段[sql_start_time 和 sql_end_time]
1 2 3 4 5 6 7 8 9 10 1 2 时间重叠的情况1
1 2 3 4 5 6 7 8 9 10 2 1 时间重叠的情况2
1 2 3 4 5 6 7 8 9 10 1 2 时间重叠的情况3
1 2 3 4 5 6 7 8 9 10 2 1 时间重叠的情况4
a)时间不重叠只有以下2种情况
1 2 3 4 5 6 7 8 9 10 1 2 时间不重叠的情况1
1 2 3 4 5 6 7 8 9 10 2 1 时间不重叠的情况2
由于不重叠的情况只有2种, 故我们直接用不重叠的情况判断即可, 如果需要判断重叠, 则直接!(不重叠的条件)即可
判断条件, 不重叠的判断
时间段a
的最大时间小于等于时间段b
的最小时间或
时间段b
的最大时间小于等于时间段a
的最小时间
sql表示
sql
select * from xtable
where (endTime <= sql_start_time or sql_end_time <= startTime)
判断条件, 重叠的判断
取不重叠的判断条件加非判断, !(
时间段a
的最大时间小于等于时间段b
的最小时间 或时间段b
的最大时间小于等于时间段a
的最小时间)
整理可得:
时间段a
的最大时间大于时间段b
的最小时间且
时间段b
的最大时间打于时间段a
的最小时间
将条件带回上面4种情况, 成立
sql表示
sql
select * from xtable
where (endTime > sql_start_time and sql_end_time > startTime)