Task Table
id name start_date expiry_date
1 Task 1 09-05-2016 11-05-2016
2 Task 2 10-05-2016 13-05-2016
3 Task 3 11-05-2016 12-05-2016
4 Task 4 17-05-2016 20-05-2016
5 Task 5 18-05-2016 26-05-2016
我需要找到给定日期范围内的所有任务,其中范围内的每个日期都在start_date和expiry_date之间。假设输入为2016年10月5日至2016年12月5日。
id name start_date expiry_date
1 Task 1 09-05-2016 11-05-2016
2 Task 2 10-05-2016 13-05-2016
3 Task 3 11-05-2016 12-05-2016
您可以使用此条件来检查两个日期范围是否重叠:
WHERE
StartA <= EndB
AND EndA >= StartB
您的查询应为:
SELECT *
FROM tbl
WHERE
start_date <= '12-05-2016'
AND expiry_date >= '10-05-2016'
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句