所以我有一张包含start
,end
,taxi
和driver
的表格。城市现在希望按月查看哪些出租车在月内以及发生任何变化时的历史数据。
因此,此抓取分配行于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')
)
答案 0 :(得分:5)
规范范围重叠检查是:
(a.start < b.end or b.end is null) and (a.end > b.start or a.end is null)
这假定
start
的正确排序&lt; end
在您的情况下,a
代表表格中的数据,而b
代表7月,所以
b.start = 2014-07-01 00:00:00
b.end = 2014-08-01 00:00:00
答案 1 :(得分:0)
这将从2012年2月起获得信息,作为一个例子。我还包括一个字段,用于标记您的出租车正在使用中,或者它结束的日期。
SELECT Year(start), Month(start),driver, taxi,
case when end > MONTH(getdate()) or end is null then 'Active' else end
FROM `taxi_assignments` WHERE
year(start)>2012 and month(start)> 2