Esta es la estructura de mi tabla de eventos.
+----+----------------------+---------------------+ | id | start_date | end_date | +----+----------------------+---------------------+ | 1 | 2020-07-01 09:00:00 | 2021-07-11 15:00:00 | +----+----------------------+---------------------+
Quiero obtener todos los registros en un período de tiempo determinado, por ejemplo, quiero obtener todos los registros que están entre 2020-07-27 - 2020-09-07. Esto es lo que he probado hasta ahora
$start_date = Carbon::parse("$req->startDate 00:00:00")->format('Ymd H:i:s'); $end_date= Carbon::parse("$req->endDate 23:59:59")->format('Ymd H:i:s'); Events::whereBetween('start_date', [$start_date , $end_date])->orWhereBetween('end_date', [$start_date , $end_date])->get();
No recupera ningún registro. ¿Pueden por favor revisarlo y guiarme en lo que me estoy perdiendo o haciendo mal?
Pruebe la consulta de la siguiente manera.
$start_date = Carbon::parse("$req->startDate 00:00:00")->format('Ymd H:i:s'); $end_date = Carbon::parse("$req->endDate 23:59:59")->format('Ymd 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();
en primer lugar, no es necesario que formatee la fecha para usarla en 'entre'... solo utilícela tal como está...
segundo: para obtener la primera hora del día o la última, puede usar: métodos 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();
Prueba este coe,
$start_date = Carbon::parse("$req->startDate 00:00:00")->format('Ymd H:i:s'); $end_date= Carbon::parse("$req->endDate 23:59:59")->format('Ymd H:i:s'); Events::whereBetween('start_date', [$start_date->toDateTimeString() , $end_date- >toDateTimeString()])->orWhereBetween('end_date', [$start_date->toDateTimeString() , $end_date->toDateTimeString()])->get();