在Laravel中使用Raw查询绑定参数

时间:2018-03-03 09:42:28

标签: laravel laravel-5

我查询了一个分页列表页面。 SELECT WHERE 部分的某些部分是原始查询。为了避免sql vularabilities,我需要为此查询使用参数绑定。它适用于 WhereRaw 查询但不适用于 SELECT 部分。

请在此处查看我的问题:

$aJob  = JobKeywords::where('job_keywords.status', 1)
                        ->where('job_keywords.expiry_date', '>=', $today);
           whereRaw('MATCH(job_title,company_name,skills) AGAINST (? IN BOOLEAN MODE) > 0', [$keyword])
      ->select([DB::Raw('job_keywords.job_id as job_id, ? as candidate_id, 1 as fts_search', [$candidateId]),"job_keywords.location as job_location_name",
        DB::raw('MATCH(job_title,company_name,skills) AGAINST (? IN BOOLEAN MODE) as score', [$keyword]),
        "job_keywords.company_name",
        "job_keywords.job_id as id","job_keywords.job_title",
         "job_keywords.skills",
         "job_keywords.expiry_date",
        "job_keywords.monthly_salary_range_min","job_keywords.monthly_salary_range_max",
        'job_keywords.min_experience_in_year',
        'job_keywords.metadata'])
->orderBy('score', 'DESC')
->paginate(10);

WhereRaw中的参数绑定工作正常,但Select(DB::Raw)内部无法正常工作。它将抛出SQLSTATE[HY093]: Invalid parameter number error。如果我们调试print_r($aJob->toSql()) and print_r($aJob->getBindings()),那么您可以看到参数inside DB::raw未计算在内。

有人对此有任何想法吗?

0 个答案:

没有答案