gpt4 book ai didi

laravel - 为每个帖子获取用户喜欢

转载 作者:行者123 更新时间:2023-12-04 17:48:37 25 4
gpt4 key购买 nike

我有一个功能可以让用户“喜欢”一个帖子(类似于 Facebook)。当我检索一个帖子(或多个帖子)时,我需要在该查询中包含有关用户是否喜欢该帖子的数据。

在我的 Post.php模型,我有以下关系:

public function likes()
{
return $this->hasMany('App\Like');
}

现在,显然,如果我执行以下查询,它将检索所有用户的所有喜欢,而不仅仅是登录用户:
$posts = Post::with('likes')
->get();

所以我的问题是,我如何创建一个关系(可能称为 userLike() ),首先检查用户是否登录,然后检索每个帖子的类似记录?

谢谢!

最佳答案

我假设 likes表有user_id .在这种情况下,您可以使用 eager loading constraint像这样:

$posts = Post::with([['likes' => function ($q) {
$q->where('user_id', auth()->id());
}])->get();

或者,您可以创建与 where 的关系条款:
public function userLikes()
{
return $this->hasMany(Like::class)->where('user_id', auth()->id());
}

然后使用它:
Post::with('userLikes')->get();

关于laravel - 为每个帖子获取用户喜欢,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46916487/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com