美文网首页laravel
laravel Eloquent的with()函数

laravel Eloquent的with()函数

作者: charmingcheng | 来源:发表于2019-04-13 09:00 被阅读0次

关于Laravel Eloquent下with() 函数只返回指定列:

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

// User.php 
public function post(){
    return $this->hasMany('post');
}
// Post.php
public function user(){
    return $this->belongsTo('user', 'cid');
}

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

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

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

select * from posts
select * from users where users.id in (select cid from post);

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

select * from posts
select id,username from users where users.id in (select cid from post);

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

方法一:在 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'));
}

相关文章

网友评论

    本文标题:laravel Eloquent的with()函数

    本文链接:https://www.haomeiwen.com/subject/geqxcqtx.html