php – Laravel 5.使用USING运算符
发布时间:2020-12-14 19:39:56 所属栏目:大数据 来源:网络整理
导读:我试图找到它很长一段时间,我无法相信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') 但如何写第二个
我试图找到它很长一段时间,我无法相信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 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |