查询集上的 Django 总和

Posted

技术标签:

【中文标题】查询集上的 Django 总和【英文标题】:Django sum on query set 【发布时间】:2019-06-08 08:37:36 【问题描述】:

我在 django 中有一个查询集,条件如下:

query_set = MyModel.objects.annotate(TWWByRuns=(
    Case(
        When(Q(toss_winner=F('winner')) & Q(win_by_runs=0), then=1),
        output_field=FloatField(), default=0)
    )
).values('TWWByRuns')

每当query_set 中的值等于1 时,我想使用django 内置求和函数来相加,就像then=1 时一样。我知道在没有条件的情况下使用 sum 函数,但在这里因为我有条件我应该在这个 query_set 中使用 sum 函数?

【问题讨论】:

【参考方案1】:

在这种特定情况下,计数更有意义:

MyModel.objects.filter(toss_winner=F('winner'), win_by_runs=0)<b>.count()</b>

因此,我们在这里简单地检查有多少 MyModel 记录满足给定条件。

【讨论】:

所以这个条件类似于检查 MyModel.toss_winner = MyModel.winner 和 MyModel.win_by_runs = 0? @Laxman:是的。因此,我们计算了满足该条件的 MyModel 记录的数量。 好的。最后一个问题。如何在 django 中检查不等于?因为据我了解,django 中没有 '!=' 运算符。 检查 win_by_runs != 0 应该是什么操作符? @Laxman:对不起,确实应该交换参数,所以MyModel.objects.filter(~Q(win_by_runs=0), toss_winner=F('winner')).count()

以上是关于查询集上的 Django 总和的主要内容,如果未能解决你的问题,请参考以下文章

在 Django 查询集上使用 iterator()

在已过滤的查询集上使用 Django 自定义管理器功能

Django 查询 - 如何按日期过滤总和?

Django:通过注释字段的总和订购查询集?

Django用相关表上的条件注释总和

Django:分组然后通过查询计算列值的总和