您好,欢迎访问一九零五行业门户网

Laravel Eloquent 中 with() 函数只返回指定列

laravel 提供了 eager loading使用 with()方法来缓解 n+1 的问题,但是在实际使用中还是存在一些问题的, with()会直接查询出表中所有的字段,而我们可能仅仅需要其中指定的某几个字段。
假如我们现在有两张表: user和 posts,每个 user 可以拥有多个 posts,而每一篇 post 只能属于一个 user。下面分别是 user model 和 post model 中定义的关系:
// user.php public function post(){ return $this->hasmany('post');}// post.phppublic function user(){ return $this->belongsto('user');}
通过 with()方法,我们可以这样获取所有的 posts 并同时查出对应的 user 信息,可以使用这样的方法:
public function getallposts() { return post::with('user')->get();}
这实际上会执行下面两句 sql 语句:
select * from `posts`select * from `users` where `users`.`id` in (, )
但是我们可能并不需要 user 表中所有的字段,例如我们只需要 id和 username两个字段:
select * from `posts`select id,username from `users` where `users`.`id` in (, )
我们可以通过下面两种方法来实现。
方法一:在 with() 中指定 post::with(array('user'=>function($query){ $query->select('id','username');}))->get();
方法二:修改 model 文件 修改 post.php 文件中 user() 方法:
public function user(){ return $this->belongsto('user')->select(array('id', 'username'));}
其它类似信息

推荐信息