我试图找到它很长一段时间,我无法相信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:答案可能很简单,很难找到“使用”这个词,因为它无处不在.
UPDATE
我要更深入地获取源代码,尝试创建范围或传递函数来加入,但即使在这个函数内部,我也无法使用此$查询.例:
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中不可能的东西.
最佳答案 所以,答案是 – 这是不可能的.
Laravel不支持此功能,这真的很难过.
我在Laravel源代码中修复它,我的PULL REQUEST在这里 – https://github.com/laravel/framework/pull/12773