English 中文(简体)
我如何在过滤过的外国密钥上排序和排程计数?
原标题:How can I sort and do pagination on a filtered foreign key count?

我有从 Entry Vote 的外国密钥, 我想排序在某个日期之前创建的 Vote 。 我如何才能以良好的方式做到这一点? 通常我会做 :

entries = Entry.objects.annotate(
    num_votes = Count( votes )).order_by( -num_votes )

page = request.GET.get( page )
paginator = Paginator(entries, 12)
try:
    entries = paginator.page(page)
except PageNotAnInteger:
    entries = paginator.page(1)
except EmptyPage:
    entries = paginator.page(paginator.num_pages)

如何分类才能只算出在某个日期之前产生的选票? 我唯一的选择就是查询DB,然后对每件事进行反复处理吗?

问题回答

如果您简单地添加到过滤器上, 它应该包含该过滤器在总和中。 您会使用相关的外国密钥名称来过滤加入的那一部分 。

entries = Entry.objects.annotate(
    num_votes = Count( votes )).order_by( -num_votes )

entries = entries.filter(votes__created__lte=some_date)




相关问题
How to get two random records with Django

How do I get two distinct random records using Django? I ve seen questions about how to get one but I need to get two random records and they must differ.

Moving (very old) Zope/Plone Site to Django

I am ask to move data from a (now offline) site driven by Plone to a new Django site. These are the version informations I have: Zope Version (unreleased version, python 2.1.3 ) Python Version 2.1....

Can Django models use MySQL functions?

Is there a way to force Django models to pass a field to a MySQL function every time the model data is read or loaded? To clarify what I mean in SQL, I want the Django model to produce something like ...

Flexible pagination in Django

I d like to implement pagination such that I can allow the user to choose the number of records per page such as 10, 25, 50 etc. How should I go about this? Is there an app I can add onto my project ...

is it convenient to urlencode all next parameters? - django

While writing code, it is pretty common to request a page with an appended "next" query string argument. For instance, in the following template code next points back to the page the user is on: &...

Pragmatically adding give-aways/freebies to an online store

Our business currently has an online store and recently we ve been offering free specials to our customers. Right now, we simply display the special and give the buyer a notice stating we will add the ...

热门标签