我对Eloquent有这样的查询,由于某种原因,它似乎忽略了我上一条语句,即只返回等于或大于给定日期的日期。
$searchCriteriaArray是我搜索的关键字所基于的数组(这是可行的)
我正在筛选的$searchDate is the日期(这不起作用)
下面是我的问题
$pool =User::select('id', 'email', 'updated_at', 'phone_number', 'headline','summary')
                    ->where(function ($query) use ($searchCriteriaArray){
                        for($i =0; $i < count($searchCriteriaArray); $i++){
                            $query->orwhere('headline', 'like', '%' . $searchCriteriaArray[$i] . '%' );
                        }
                    })->orWhere(function ($query) use ($searchCriteriaArray){
                        for($i =0; $i < count($searchCriteriaArray); $i++){
                            $query->orwhere('summary', 'like', '%' . $searchCriteriaArray[$i] . '%' );
                        }
                    })->where('updated_at', '>= ',$searchDate)
                    ->orderBy('updated_at', 'desc')
                    ->paginate(50);我已经看了一些其他的帖子,包括Laravel Eloquent compare date from datetime field。然而,这并没有解决我的问题。为什么Eloquent忽略了我的最后一条where语句,我该如何解决这个问题?
发布于 2018-04-26 08:45:05
有人发布了答案,然后将其删除。我需要添加这一行
 ->where(function ($query) use ($searchDate){
                        $query->orwhere('updated_at', '>=', $searchDate);
                    })https://stackoverflow.com/questions/50032923
复制相似问题