Glu*_*ear 4 php mysql search inner-join laravel
我有 2 张桌子,projects和jobs. jobs有一个名为project_id. 在 Laravel 5.2 中,我想运行一个搜索,该搜索将返回属于给定搜索词的项目的所有工作。此 SQL 有效:
SELECT jobs.*, projects.name FROM jobs INNER JOIN projects ON jobs.project_id = projects.id WHERE projects.name LIKE "%$keyword%"
Run Code Online (Sandbox Code Playgroud)
在我的Job.php模型中,我创建了一个 scope 方法,该方法出错:
public function scopeSearch($query, $keyword)
{
if ($keyword != '') {
$query->where(function($query) use ($keyword) {
$query->where('projects.name', 'LIKE', '%' . $keyword . '%')->join('projects', 'jobs.project_id', '=', 'projects.id');
});
}
return $query;
}
Run Code Online (Sandbox Code Playgroud)
这会产生错误:
列未发现:在1054未知列'projects.name 'where子句'(SQL:SELECT * FROM
jobs哪里(projects。nameLIKE%测试%))
在我的JobsController.php我有:
$searchResults = Job::Search($searchTerm)->get();
Run Code Online (Sandbox Code Playgroud)
该参数$query在where(function($query)不是$query你传入public function scopeSearch($query, $keyword)
您可以仅使用如下查询将其删除(如@Rob 所述)
public function scopeSearch($query, $keyword)
{
if ($keyword != '') {
$query->where('projects.name', 'LIKE', '%' . $keyword . '%')->join('projects', 'jobs.project_id', '=', 'projects.id');
}
return $query;
}
Run Code Online (Sandbox Code Playgroud)
或者你需要包括$queryin use()
$query->where(function() use ($keyword, $query)
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
8733 次 |
| 最近记录: |