我正在从事一个社交网络项目!! 它具有保存用户数据,朋友数据和帖子数据的模型
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)
答案 0 :(得分:0)
您可以通过以下关系获取登录用户朋友的所有帖子:
friends_posts = MediaDB.objects.filter(username__user_friend__request_id=request.user)
请注意,您的某些命名有些奇怪; MediaDB上的username
字段指向用户,因此应该仅称为user
,而Friends上的字段甚至更陌生;没有“请求”,它们也不是“ id”,反向关系根本无法解释它们是什么。