SQL连续出现基于可用性的查询

时间:2016-10-16 17:41:32

标签: mysql sql find-occurrences availability

我试图在SQL上创建一个非常复杂的东西,更具体地说是MySQL。

数据库处理汽车租赁,雪花图案的主要表格看起来有点像:

  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列表绰绰有余......我真的不知道如何设置这样的查询。

如果可以提供帮助:我确实有另一张表中所有车牌的清单。

无论哪种方式,谢谢!

1 个答案:

答案 0 :(得分:0)

我认为为此目的使用可用性而不是租赁要简单得多。

所以:

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)
      );

这可以处理自由时段涵盖整个范围或开始/结束的各种条件。

毫无疑问,这个逻辑中有一个错误的错误(是一辆汽车在它返回的同一天可用)。这应该为您提供解决问题的可靠方法。

顺便说一句,您还应该包括从未租过的汽车。但是,对于您在问题中描述的表格,这是不可能的。