Laravel Eloquent - 相当于第一个()?

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Laravel Eloquent - 相当于第一个()?相关的知识,希望对你有一定的参考价值。

我有一些模型,如用户,发布,评论等。

在用户中,我有:

public function posts() 
{
   return $this->hasMany('Post'); 
}

我可以通过$customer->posts()->first()获得第一篇文章,但如果我想获得最新帖子怎么办?我看不到最后一个()。

hasManyThrough关系进一步加剧了这种情况(遗憾的是我们继承了一个古怪的模式):

public function comments() 
{
     return $this->hasManyThrough('Comment', 'Post');
}

如果我尝试做一个$this->comments()->orderBy('comments.id', 'desc')->first();它返回一个User对象?

答案

没有这个

// User model
$this->comments()->orderBy('comments.id', 'desc')->first();

将不会返回User模型。

为了得到你所要求的,只需这样做:

$customer->posts()->latest()->first();
另一答案

你说There is no last() as I can see,但实际上也有一个last()方法,所以你可以使用它像:

$customer->posts->last();

请注意,它不是像你在使用$customer->posts()->last()的示例中使用的那样使用first()

以上是关于Laravel Eloquent - 相当于第一个()?的主要内容,如果未能解决你的问题,请参考以下文章

Laravel Eloquent 关系——相当于 MYSQL “join”

Laravel Eloquent 相当复杂的关系

如何在 Laravel 5.8 中使用 Eloquent 进行查询?

Laravel Eloquent belongsToMany()返回第一个()

Laravel Eloquent ORM - 获取第一个和第三个表数据

如何在 Eloquent 模型中使用 Laravel Livewire?