带有内部连接的 Laravel 范围

Posted

技术标签:

【中文标题】带有内部连接的 Laravel 范围【英文标题】:Laravel scope with inner join 【发布时间】:2016-11-16 16:11:29 【问题描述】:

我有 2 张桌子,projectsjobsjobs 有一个名为 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 jobs where (projects.name LIKE %test%))

在我的JobsController.php 我有:

$searchResults = Job::Search($searchTerm)->get();

【问题讨论】:

您可以在控制器中发布查询生成器语句吗?如果您在模型中创建了范围,您只是在使用它 啊,谢谢。实际上,我没有在您确定问题的范围内滚动。似乎您不能在嵌套的 where 子句中添加连接。尝试删除嵌套,只需使用以 $query->where('projects.name... 开头的行在您的 of 语句中 【参考方案1】:

where(function($query)中的参数$query不是你传入public function scopeSearch($query, $keyword)$query

您可以使用下面的查询将其删除(如@Rob 所述)

public function scopeSearch($query, $keyword)

    if ($keyword != '') 
        $query->where('projects.name', 'LIKE', '%' . $keyword . '%')->join('projects', 'jobs.project_id', '=', 'projects.id');
    
    return $query;

或者你需要在 use() 中包含$query

$query->where(function() use ($keyword, $query)

【讨论】:

以上是关于带有内部连接的 Laravel 范围的主要内容,如果未能解决你的问题,请参考以下文章

Laravel 护照范围

带有 Redis 的 Laravel 广播无法工作/连接?

带有条件的 Laravel 连接查询

Laravel 5.4 OAuth 与 Dingo 内部请求

Laravel Eloquent 查询,带有连接、计数和分组依据

使用 Laravel 的查询构建器或 Eloquent 将一个表与一个临时表进行内部连接