php – Laravel:如何通过Eager Loading获取基表的选定列?

php – Laravel:如何通过Eager Loading获取基表的选定列?,第1张

概述例如这里的表结构. User------id-role_id-fname-lname-country_code-mobile-password-remember_token-email-address-location_id 另一张桌子 Role------id-name 现在,如果我想要来自带有角色表的用户表的所有用户信息,我将这样写. $user = User : 例如这里的表结构.

User------ID-role_ID-fname-lname-country_code-mobile-password-remember_token-email-address-location_ID

另一张桌子

Role------ID-name

现在,如果我想要来自带有角色表的用户表的所有用户信息,我将这样写.

$user = User :: with(‘Role’) – > where(‘users.ID’,$ID) – > first() – > toArray();

但它将从用户表中获取所有数据.
我需要的是具有预先加载的用户表的选定列.
仅像fname,lname,mobile,来自用户表的电子邮件和来自角色表的role_name.

我知道如何选择关联表的特定列,如下所示.

public function Role(){    return $this->belongsTo('App\Role')->select('ID','name as role_name');}

但是如何使用with()选择User表的特定列?

解决方法 尝试这样的事情(我用头写,测试它):

$user = User::with('Role')            ->where('users.ID',$ID)            ->select('users.fname','users.lname','users.mobile','users.email','roles.name as role_name')            ->first()->toArray();

或直接使用joints.

总结

以上是内存溢出为你收集整理的php – Laravel:如何通过Eager Loading获取基表的选定列?全部内容,希望文章能够帮你解决php – Laravel:如何通过Eager Loading获取基表的选定列?所遇到的程序开发问题。

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

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

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

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

发表评论

登录后才能评论

评论列表(0条)

保存