ICode9

精准搜索请尝试: 精确搜索
首页 > 数据库> 文章详细

mysql – 7月份谁有车

2019-06-09 21:11:03  阅读:154  来源: 互联网

标签:mysql sql date-range


所以我有一张桌子,有开始,结束,出租车和司机.城市现在希望按月查看哪些出租车在哪个月,以及何时发生任何变化.

因此,此抓取分配行于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

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有