如何查看特定日期的预订ID?

时间:2019-02-16 08:33:27

标签: php mysql codeigniter-3

我有一张桌子,记录如下表所示。

id | list_id |venue_id |name | start_date          | end_date           |start_time |end_time | days 
1  |       1 |  1      |asdf |  2019-02-02 14:05:54| 2019-02-28 14:05:54|05:30      |10:00    | 1,2,3
2  |       7 |  2      |awed |  2019-02-10 15:02:24| 2019-02-20 15:02:24|07:30      |14:00    | 2,5
3  |       7 |  1      |mjgd |  2019-02-04 09:05:54| 2019-02-13 09:05:54|09:30      |18:00    | 4

现在我正在做的是我必须检查start_time和end_time范围(如果在该范围内),然后检查start_date和end_date在该范围内(如果找到),然后显示记录。

因此下面的查询适用于上述情况

SELECT * FROM batch_list 
WHERE venue_id=1 AND (start_date <= '2019-03-01') AND (start_time <= '13:00:00') AND (end_date >= '2019-02-04') AND (end_time >= '10:00:00')";

现在我还有一列days。因此,我正在做的是venue_id=1被预订一天,即一天1,2,3,4,然后显示记录。

那么我该如何查看ID为1的预定日期呢?

那我对用户有什么查询以检查表中是否已经有场地ID = 1的日期?

function fetchBatches($venue_id,$new_batch_start_date,$new_batch_end_date,$new_batch_start_time,$new_batch_end_time,$days)
    {
$where="venue_id=$venue_id AND (start_date <= '$new_batch_end_date') AND (start_time <= '$new_batch_end_time') AND (end_date >= '$new_batch_start_date') AND (end_time >= '$new_batch_start_time')";

        $result =$this->db->select('*')    
                    ->from('batch_list')
                    ->where($where)
                    ->get()
                    ->result();
            if ($result) {
                 return $result;
            }
            else{
                 return 0;
            }

    }

您能在这个问题上帮助我吗?

1 个答案:

答案 0 :(得分:0)

用于检查一个范围是否与另一个范围重叠的查询可能看起来像这样:

SELECT x.*
  FROM my_table x
 WHERE x.start_datetime < :end_datetime
   AND x.end\datetime >= :start_datetime;

但是实际上您的问题比这更广泛