mysql – 7月份谁有车
作者:互联网
所以我有一张桌子,有开始,结束,出租车和司机.城市现在希望按月查看哪些出租车在哪个月,以及何时发生任何变化.
因此,此抓取分配行于2014年7月开始,于2014年7月结束,或正在进行(在7月之前开始,在月之后结束或尚未结束).
我的问题是,是否有更高效或更优雅的查询来获取这些行?
SELECT * FROM `taxi_assignments` WHERE
(`start` BETWEEN '2014-07-01 00:00:00' AND '2014-07-31 23:59:59')
OR (`end` BETWEEN '2014-07-01 00:00:00' AND '2014-07-31 23:59:59')
OR (`start` < '2014-07-01 00:00:00' AND
(`end` > '2014-07-31 23:59:59' OR `end` = '0000-00-00 00:00:00')
)
解决方法:
规范范围重叠检查是:
(a.start < b.end or b.end is null) and (a.end > b.start or a.end is null)
这假定
>正确的开始顺序<结束
>时间范围在右侧是半开的,即范围包括开始时刻但不包括结束时刻
> null用于尚未完成的范围中的结束日期
>开始日期不能为空
在您的情况下,a代表表中的数据,而b代表7月,所以
b.start = 2014-07-01 00:00:00
b.end = 2014-08-01 00:00:00
标签:mysql,sql,date-range 来源: https://codeday.me/bug/20190609/1207550.html