Django计算一对多关系

4
所以我有两个表,文章分类
代码:
model.py
class Category(models.Model):
     category = models.CharField(max_length=100)

     def __str__(self):
         return self.category

class Post(models.Model):
     title = models.CharField(max_length=200)
     author = models.CharField(max_length=40)
     category = models.ForeignKey(Category)
     content = models.TextField()
     created_date = models.DateTimeField(default=timezone.now)

     class Meta:
         ordering = ['-created_date']

     def __str__(self):
         return self.title + ' - ' + str(self.created_date.date())

我想在模板中实现分类列表。例如,我有几个分类:

体育(2) 2-体育分类中的文章数量

模板代码:
<h3>Categories</h3>
    <ul class="nav navbar-stacked">
        {% for category in categories %}
            <li><a href="#">{{ category }}<span class="pull-right">(
                {{ **post.category.count** }}
            )</span></a></li>
        {% endfor %}
    </ul>

这怎么实现?
1个回答

5
在模板中,您可以执行以下操作:
{{ category.post_set.count }}

获得映射到给定类别对象的categoryPost对象计数。

您可以在此处了解有关反向查询的更多信息。


还有4分钟,如果不到15分钟,好像我无法接受 :) - Šarūnas Rakauskas

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接