繁体   English   中英

搜索开始和结束日期列之间的开始和结束日期 MySQL,Laravel

[英]Search Start & End dates between start and end date columns MySQL,Laravel

这是我的事件表结构。

+----+----------------------+---------------------+
| id |      start_date      |      end_date       |
+----+----------------------+---------------------+
|  1 | 2020-07-01 09:00:00  | 2021-07-11 15:00:00 |
+----+----------------------+---------------------+

我想获取给定时间段内的所有记录,例如,我想获取 2020-07-27 - 2020-09-07 之间的所有记录。 这是我迄今为止尝试过的

$start_date = Carbon::parse("$req->startDate 00:00:00")->format('Y-m-d H:i:s');
$end_date= Carbon::parse("$req->endDate 23:59:59")->format('Y-m-d H:i:s');


Events::whereBetween('start_date', [$start_date , $end_date])->orWhereBetween('end_date', [$start_date , $end_date])->get();

它不获取任何记录。 你们可以检查一下并指导我我缺少什么或做错了什么吗?

尝试如下查询。

$start_date = Carbon::parse("$req->startDate 00:00:00")->format('Y-m-d H:i:s');
$end_date = Carbon::parse("$req->endDate 23:59:59")->format('Y-m-d H:i:s');

$events = Events::where([['start_date','<=',$start_date],['end_date','>=',$end_date]])
              ->orwhereBetween('start_date',array($start_date,$end_date))
             ->orWhereBetween('end_date',array($start_date,$end_date))->get();

首先,您不需要格式化日期以在“之间”中使用它......只需按原样使用它......

第二:获取一天中的第一个小时或最后一个小时,您可以使用: startOfDay(),endOfDay() 方法:

$start_date = Carbon::parse($req->startDate )->startOfDay();
$end_date= Carbon::parse($req->endDate)->endOfDay();
Events::whereBetween('start_date', [$start_date , $end_date])->orWhereBetween('end_date', [$start_date , $end_date])->get();

试试这个coe

$start_date = Carbon::parse("$req->startDate 00:00:00")->format('Y-m-d H:i:s');
$end_date= Carbon::parse("$req->endDate 23:59:59")->format('Y-m-d H:i:s');


Events::whereBetween('start_date', [$start_date->toDateTimeString() , $end_date- 
>toDateTimeString()])->orWhereBetween('end_date', [$start_date->toDateTimeString() , 
$end_date->toDateTimeString()])->get();

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM