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获取基表的选定列?所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)