Django-如何检索已登录用户好友的帖子数据

时间:2018-06-30 15:20:25

标签: django postgresql django-models django-rest-framework django-serializer

我正在从事一个社交网络项目!! 它具有保存用户数据,朋友数据和帖子数据的模型

Users -> User Info
Friends -> User friends
Media -> All Posts from users

如何获取已登录用户的朋友的帖子。

class Friends(models.Model):
    """Model for saving relationship of user and friends"""
    request_id = models.ForeignKey(User,on_delete=models.CASCADE,related_name='current_user')
    friend_id = models.ForeignKey(User,on_delete=models.CASCADE,related_name='user_friend')
    created_on = models.DateTimeField(auto_now_add=True,auto_now=False)

class MediaDB(models.Model):
    """All User Feed Items"""
    username = models.ForeignKey(User,on_delete=models.CASCADE,)
    m_url = models.FileField(blank=True,null=True)
    timeStamp = models.DateTimeField(auto_now_add=True,auto_now=False)
    location = models.CharField(max_length=30)
    likes_count = models.BigIntegerField(default=0)

1 个答案:

答案 0 :(得分:0)

您可以通过以下关系获取登录用户朋友的所有帖子:

friends_posts = MediaDB.objects.filter(username__user_friend__request_id=request.user)

请注意,您的某些命名有些奇怪; MediaDB上的username字段指向用户,因此应该仅称为user,而Friends上的字段甚至更陌生;没有“请求”,它们也不是“ id”,反向关系根本无法解释它们是什么。

相关问题