Django:查询多个外键

时间:2012-05-14 22:20:30

标签: python django orm models

首先,我确定这是一个简单的问题。我刚刚开始使用Django,而且正如所有初学者所做的那样,我想我会构建一个简单的博客。

我有一个简单的数据模型,一个Post模型,其中包含通过FK链接到用户的链接。

models.py

class Post(TimeStampedActivate):
    """
    A blog post
    """
    title = models.CharField(max_length=255)
    slug = models.SlugField()
    excerpt = models.TextField(blank=True)
    body = models.TextField()
    publish_at = models.DateTimeField(default=datetime.datetime.now())
    created = models.DateTimeField(auto_now_add=True)
    modified = models.DateTimeField(auto_now=True)
    active = models.BooleanField(default=False, help_text='Is the blog post active?')
    user = models.ForeignKey(User, related_name='post_user')

    def __unicode__(self):
        return self.title

然后,我想要一个页面,列出所有帖子以及创建帖子的人的用户名。我目前的观点如下:

views.py

def index(request):
    posts = Post.objects.filter(active=True)   
    user = User.objects.get(id=1)
    return render(request, 'blog/index.html', {'posts': posts, 'user': user})

我的模板 目前,这只显示与ID为1匹配的用户名。

{% for post in posts %}
    <h2><a href="{{ post.get_absolute_url }}">{{ post.title }}</a></h2>
    <p>{{ post.excerpt|truncatewords:30 }}</p>
    <p>Posted by {{ user.first_name }} {{ user.last_name }}</p>
{% endfor %}

如何修改我的views.py文件以确保我获得负责该帖子的用户的名字和姓氏?

2 个答案:

答案 0 :(得分:3)

查看:

def index(request):
    posts = Post.objects.filter(active=True)   
    return render(request, 'blog/index.html', {'posts': posts})

模板:

{% for post in posts %}
    <h2><a href="{{ post.get_absolute_url }}">{{ post.title }}</a></h2>
    <p>{{ post.excerpt|truncatewords:30 }}</p>
    <p>Posted by {{ post.user.first_name }} {{ post.user.last_name }}</p>
{% endfor %}

答案 1 :(得分:1)

在模板中使用“post.user”而不只是“user”。

{{ post.user.first_name }} {{ post.user.last_name }}

“user”是当前登录的用户。

如果您使用RequestContext&amp;将auth添加到TEMPLATE_CONTEXT_PROCESSORS,用户等于request.user。 https://docs.djangoproject.com/en/dev/topics/auth/#authentication-data-in-templates