为了账号安全,请及时绑定邮箱和手机立即绑定

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

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

PHP
POPMUISE 2023-07-08 20:15:48
这是我的事件表结构。+----+----------------------+---------------------+| 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();它不获取任何记录。你们能检查一下并指导我遗漏或做错了什么吗?
查看完整描述

3 回答

?
犯罪嫌疑人X

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


查看完整回答
反对 回复 2023-07-08
?
ITMISS

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



查看完整回答
反对 回复 2023-07-08
?
三国纷争

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


查看完整回答
反对 回复 2023-07-08
  • 3 回答
  • 0 关注
  • 196 浏览

添加回答

举报

0/150
提交
取消
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号