3 回答

TA貢獻2080條經驗 獲得超4個贊
嘗試如下查詢。
$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();

TA貢獻1871條經驗 獲得超8個贊
首先,您不需要格式化日期以在“之間”使用它......只需按原樣使用它......
第二:要獲取一天中的第一個小時或最后一個小時,您可以使用: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();

TA貢獻1804條經驗 獲得超7個贊
試試這個科,
$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();
- 3 回答
- 0 關注
- 225 瀏覽
添加回答
舉報