SQL 连续出现基于可用性的查询
SQL consecutive occurrences for availability based query
我有点难以尝试在 SQL 上创建一个非常复杂的东西,更具体地说 MySQL。
数据库涉及租车,主要table什么是雪花图案有点像:
id | rent_start | rent_duration | rent_end | customerID | carId
-----------------------------------------------------------------------------------
203 | 2016-10-03 | 5 | 2016-11-07 | 16545 | 4543
125 | 2016-10-20 | 9 | 2016-10-28 | 54452 | 5465
405 | 2016-11-01 | 2 | 2016-01-02 | 43565 | 346
我的目标是创建一个允许给定的查询
1) 周期范围,例如:从 2016-10-03 到 2016-11-03
2)天数,例如:10
允许我检索在 10 月 10 日到 11 日之间至少连续 10 天实际可用的汽车。
这些汽车的 ID 列表绰绰有余...我真的不知道如何设置这样的查询。
如果有帮助:我在另一个 table 中有所有汽车 ID 的列表。
无论如何,谢谢!
我认为为此目的,使用可用性而不是租金要简单得多。
所以:
select r.car_id, r.rent_end as avail_start,
(select min(r2.rent_start
from rentals r2
where r2.car_id = r.car_id and r2.rent_start > r.rent_start
) as avail_end
from rentals r;
那么,对于您的查询,您至少需要 10 天。您可以为此目的使用 having
子句或子查询:
select r.*
from (select r.car_id, r.rent_end as avail_start,
(select min(r2.rent_start
from rentals r2
where r2.car_id = r.car_id and r2.rent_start > r.rent_start
) as avail_end
from rentals r
) r
where datediff(avail_end, avail_start) >= $days;
最后,您需要在您指定的日期期间:
select r.*
from (select r.car_id, r.rent_end as avail_start,
(select min(r2.rent_start
from rentals r2
where r2.car_id = r.car_id and r2.rent_start > r.rent_start
) as avail_end
from rentals r
) r
where datediff(avail_end, avail_start) >= $days and
( (avail_end > $end and avail_start < $start) or
(avail_start <= $start and avail_end >= $start + interval 10 day) or
(avail_start > $start and avail_start + interval 10 day <= $end)
);
这处理了免费期覆盖整个范围或范围内 starts/ends 的各种情况。
毫无疑问,此逻辑中存在差一错误(是否有同一天可用的汽车 returns)。这应该为您提供解决问题的可靠方法。
顺便说一句,你还应该包括从未租过的汽车。但这对于您在问题中描述的表格是不可能的。
我有点难以尝试在 SQL 上创建一个非常复杂的东西,更具体地说 MySQL。
数据库涉及租车,主要table什么是雪花图案有点像:
id | rent_start | rent_duration | rent_end | customerID | carId
-----------------------------------------------------------------------------------
203 | 2016-10-03 | 5 | 2016-11-07 | 16545 | 4543
125 | 2016-10-20 | 9 | 2016-10-28 | 54452 | 5465
405 | 2016-11-01 | 2 | 2016-01-02 | 43565 | 346
我的目标是创建一个允许给定的查询
1) 周期范围,例如:从 2016-10-03 到 2016-11-03 2)天数,例如:10
允许我检索在 10 月 10 日到 11 日之间至少连续 10 天实际可用的汽车。 这些汽车的 ID 列表绰绰有余...我真的不知道如何设置这样的查询。
如果有帮助:我在另一个 table 中有所有汽车 ID 的列表。
无论如何,谢谢!
我认为为此目的,使用可用性而不是租金要简单得多。
所以:
select r.car_id, r.rent_end as avail_start,
(select min(r2.rent_start
from rentals r2
where r2.car_id = r.car_id and r2.rent_start > r.rent_start
) as avail_end
from rentals r;
那么,对于您的查询,您至少需要 10 天。您可以为此目的使用 having
子句或子查询:
select r.*
from (select r.car_id, r.rent_end as avail_start,
(select min(r2.rent_start
from rentals r2
where r2.car_id = r.car_id and r2.rent_start > r.rent_start
) as avail_end
from rentals r
) r
where datediff(avail_end, avail_start) >= $days;
最后,您需要在您指定的日期期间:
select r.*
from (select r.car_id, r.rent_end as avail_start,
(select min(r2.rent_start
from rentals r2
where r2.car_id = r.car_id and r2.rent_start > r.rent_start
) as avail_end
from rentals r
) r
where datediff(avail_end, avail_start) >= $days and
( (avail_end > $end and avail_start < $start) or
(avail_start <= $start and avail_end >= $start + interval 10 day) or
(avail_start > $start and avail_start + interval 10 day <= $end)
);
这处理了免费期覆盖整个范围或范围内 starts/ends 的各种情况。
毫无疑问,此逻辑中存在差一错误(是否有同一天可用的汽车 returns)。这应该为您提供解决问题的可靠方法。
顺便说一句,你还应该包括从未租过的汽车。但这对于您在问题中描述的表格是不可能的。