Laravel 5.使用USING运算符

时间:2016-03-18 04:24:37

标签: php laravel join using

我试图找到它很长一段时间了,我无法相信Laravel没有这个功能。

所以,我可以写:

select * from a join b where a.id = b.id

或更漂亮:

select * from a join b using(id)

Laravel的第一个案例很简单:

$query->leftJoin('b', 'a.id', '=', 'b.id')

但如何写第二个案例?我希望它应该简单而简短,例如:

$query->joinUsing('b', 'id')

但是没有这样的方法,我找不到它。

PS:答案可能非常简单,很难通过单词"使用"找到答案,因为它无处不在。

更新

我要更深入地获取源代码,尝试制作作用域或传递函数来加入,但即使在此函数内部,我也无法使用此$查询。例如:

public function scopeJoinUsing($query, $table, $field) {
    sql($query->join(\DB::raw("USING(`{$field}`)")));
    // return 
    // inner join `b` on USING(`id`)  ``
    // yes, with "on" and with empty quotes
    sql($query->addSelect(\DB::raw("USING(`{$field}`)")));
    // return 
    // inner join `b` USING(`id`) 
    // but in fields place, before "FROM", which is very logic :)
}

所以即使忘记了范围,我也无法在DB :: raw()中这样做,所以这是不可能的......首次我在Laravel中看到了一些不可能的东西。

1 个答案:

答案 0 :(得分:1)

所以,答案是 - 这是不可能的。

Laravel不支持此功能,这真的很难过。

我在Laravel源代码中解决了这个问题,我在此处提出请求 - https://github.com/laravel/framework/pull/12773