我想做一个‘时间线’包含所有微博帖子从一个用户,以及他所关注的所有用户。我希望所有这些帖子都按日期排序,但我如何“联接”这些帖子,因为“跟随”关系在另一个表中,所以我必须在两个表之间进行某种联接,以获取数据。
目前,在我的“时间线”中,只显示博客所有者的博客帖子,我使用的查询如下:
blog = New.objects.filter(created_by = request.user) 但我想用他关注的人的帖子加入这三个帖子,意思是:
following = Relations.objects.filter(initiated_by = request.user)其中,Relations是'Follow relation‘表。
我该怎么做呢?
我的模型:
class New(models.Model):
post = models.CharField(max_length=120)
date = models.DateTimeField(auto_now_add=True)
created_by = models.ForeignKey(User, blank=True)
objects = NewManager()
class Relations(models.Model):
initiated_by = models.ForeignKey(User, editable=False, related_name = 'initiator')
date_initiated = models.DateTimeField(auto_now=True, editable = False)
follow = models.ForeignKey(User, editable = False, related_name = "follow")
date_follow = models.DateTimeField(auto_now=True, editable = False)发布于 2010-06-27 21:32:49
可能类似于(使用Q objects):
blogs = New.objects.filter(Q(created_by = request.user) | Q(relations_set__initiated_by = request.user))这里假设您有一个从Relations到New的外键。参见the documentation about following relationships backward。
如果您的Relations模型没有指向New的外键,而是指向users表的外键,比如following = models.ForeignKey(User),那么您可以这样做
blogs = New.objects.filter(Q(created_by = request.user) | Q(created_by__follow__initiated_by = request.user))现在,从Relations模型到用户模型的外键应该具有related_name = 'follow'。
https://stackoverflow.com/questions/3127396
复制相似问题