欢迎各位兄弟 发布技术文章

这里的技术是共享的

You are here

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

shiping1 的头像

Laravel 提供了 Eager Loading 使用 with() 方法来缓解 N+1 的问题,但是在实际使用中还是存在一些问题的,with() 会直接查询出表中所有的字段,而我们可能仅仅需要其中指定的某几个字段。

 

假如我们现在有两张表:user 和 posts,每个 User 可以拥有多个 Posts,而每一篇 Post 只能属于一个 User。下面分别是 User Model 和 Post Model 中定义的关系:


  1. // User.php
  2. public function post(){
  3. return $this->hasMany('post');
  4. }
  5.  
  6.  
  7. // Post.php
  8. public function user(){
  9. return $this->belongsTo('user');
  10. }

通过 with() 方法,我们可以这样获取所有的 Posts 并同时查出对应的 User 信息,可以使用这样的方法:


  1. public function getAllPosts() {
  2. return Post::with('user')->get();
  3. }

这实际上会执行下面两句 SQL 语句:


  1. select * from `posts`
  2. select * from `users` where `users`.`id` in (<1>, <2>)

但是我们可能并不需要 User 表中所有的字段,例如我们只需要 id 和 username 两个字段:


  1. select * from `posts`
  2. select id,username from `users` where `users`.`id` in (<1>, <2>)

我们可以通过下面两种方法来实现。

方法一:在 with() 中指定


  1. Post::with(array('user'=>function($query){
  2. $query->select('id','username');
  3. }))->get();

方法二:修改 Model 文件

修改 Post.php 文件中 user() 方法:


  1. public function user()
  2. {
  3. return $this->belongsTo('User')->select(array('id', 'username'));
  4. }

 
 
转载请注明来源:Laravel Eloquent 中 with() 函数只返回指定列 - Specs' Blog-就爱PHP

本文共 1 个回复


普通分类: