【发布时间】:2016-11-16 16:11:29
【问题描述】:
我有 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%"
在我的Job.php 模型中,我创建了一个范围方法,但出现错误:
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;
}
这会产生错误:
找不到列:1054 未知列 'projects.name' 在 'where 子句' (SQL: select * from
jobswhere (projects.nameLIKE %test%))
在我的JobsController.php 我有:
$searchResults = Job::Search($searchTerm)->get();
【问题讨论】:
-
您可以在控制器中发布查询生成器语句吗?如果您在模型中创建了范围,您只是在使用它
-
啊,谢谢。实际上,我没有在您确定问题的范围内滚动。似乎您不能在嵌套的 where 子句中添加连接。尝试删除嵌套,只需使用以 $query->where('projects.name... 开头的行在您的 of 语句中
标签: php mysql laravel search inner-join