首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >通过Laravel Query和Eloquent混合3次搜索

通过Laravel Query和Eloquent混合3次搜索
EN

Stack Overflow用户
提问于 2017-11-01 17:18:12
回答 1查看 128关注 0票数 1

我尝试使用Laravel Eloquent和查询构建器进行3个查询。我的第一个尝试是查找彼此如何第一个是按user_name & customer_name搜索,另一个是按日期搜索,但当我混合这三个查询时不起作用。我认为申报的顺序似乎是错的。你能帮我一下吗?

代码语言:javascript
复制
public function job_history_search(Request $request) 
{ 
   $jobs = Job::where('user_name', 'like', '%'.$request->name.'%')
   ->orWhere('customer_name', 'like', '%'.$request->name.'%')
   ->whereBetween('created_at', array(
   (Carbon::parse($request->input('datepicker_from'))->startOfDay()),
   (Carbon::parse($request->input('datepicker_to'))->endOfDay())))
   ->orderBy('created_at', 'desc') 
   ->paginate(15);

   return view('jobs.index', ['jobs' => $jobs]); 
}
EN

回答 1

Stack Overflow用户

发布于 2017-11-01 17:29:30

您应该像这样执行where子句:

代码语言:javascript
复制
Job::where(function ($query) use ($request) {
    return $query->where('customer_name', 'LIKE', $request->name . '%')
          ->orWhere('user_name', 'LIKE', $request->name .'%');
})
 ->whereBetween('created_at', array(
     (Carbon::parse($request->input('datepicker_from'))->startOfDay()),
     (Carbon::parse($request->input('datepicker_to'))->endOfDay())))
 ->orderBy('created_at', 'desc') 
 ->paginate(15);

对于像SQL中开头没有%的优化用法,请仅在LIKE语句的末尾使用它,以便使用SQL索引以获得更快的结果

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/47051591

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档