php – Laravel 5.使用USING运算符

php – Laravel 5.使用USING运算符,第1张

概述我试图找到它很长一段时间,我无法相信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

总结

以上是内存溢出为你收集整理的php – Laravel 5.使用USING运算符全部内容,希望文章能够帮你解决php – Laravel 5.使用USING运算符所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/1251406.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-07
下一篇 2022-06-07

发表评论

登录后才能评论

评论列表(0条)

保存