首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Django 'timeline‘

Django 'timeline‘
EN

Stack Overflow用户
提问于 2010-06-27 21:02:38
回答 1查看 534关注 0票数 1

我想做一个‘时间线’包含所有微博帖子从一个用户,以及他所关注的所有用户。我希望所有这些帖子都按日期排序,但我如何“联接”这些帖子,因为“跟随”关系在另一个表中,所以我必须在两个表之间进行某种联接,以获取数据。

目前,在我的“时间线”中,只显示博客所有者的博客帖子,我使用的查询如下:

代码语言:javascript
复制
     blog = New.objects.filter(created_by = request.user) 

但我想用他关注的人的帖子加入这三个帖子,意思是:

代码语言:javascript
复制
    following = Relations.objects.filter(initiated_by = request.user)

其中,Relations是'Follow relation‘表。

我该怎么做呢?

我的模型:

代码语言:javascript
复制
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)
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2010-06-27 21:32:49

可能类似于(使用Q objects):

代码语言:javascript
复制
blogs = New.objects.filter(Q(created_by = request.user) | Q(relations_set__initiated_by = request.user))

这里假设您有一个从RelationsNew的外键。参见the documentation about following relationships backward

如果您的Relations模型没有指向New的外键,而是指向users表的外键,比如following = models.ForeignKey(User),那么您可以这样做

代码语言:javascript
复制
blogs = New.objects.filter(Q(created_by = request.user) | Q(created_by__follow__initiated_by = request.user))

现在,从Relations模型到用户模型的外键应该具有related_name = 'follow'

票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/3127396

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档