繁体   English   中英

搜索查询在Laravel中无法正常运行

[英]Search Query not functioning properly in Laravel

public static function searchSubmissions($request, $candidateIds = array(),$isscontact = NULL){
      $querys = DB::table('submissions')->select('submissions.*');
  if ( Input::has('candidatename') and $request->input('candidatename') != NULL){
      $querys->join('candidates','candidates.candidateid','=','submissions.candidateid');
      $querys->where('candidates.firstname', 'LIKE', '%'. $request->input('candidatename').'%')->orWhere('candidates.lastname', 'LIKE', '%'. $request->input('candidatename') .'%')->where('submissions.status','1');
  }
   $result = $querys->paginate(PAGELIMIT);

  return $result ;
}

如果我在搜索字段中输入“ john”或“ peter”,这就是我的搜索查询,它可以正常工作。 如果我输入全名“约翰·彼得”,则对我不起作用。 在我的数据库中,我有两个字段“ firstname”“ lastname”

我认为,您需要重构代码以使其正常工作。

$names = explode(' ', $request->input('candidatename'));

if (!empty($names)) {
    foreach ($names as $name) {
        $querys = $querys->orWhere('candidates.firstname', 'LIKE', '%'. $name .'%');
        $querys = $querys->orWhere('candidates.lastname', 'LIKE', '%'. $name .'%');
    }
}

看看这个https://laravel.com/docs/5.4/queries#parameter-grouping

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM