如何编写Django查询,其中WHERE条件的左侧是数学表达式?

问题描述 投票:1回答:2

我正在使用Django,Python 3.7和PostGres 9.5。我有一个包含以下字段的模型......

class DomainTrackerStat(models.Model):
    domain = models.CharField(max_length=255)
        ...
    num_negative_articles = models.IntegerField(default=0, null=False)
    num_positive_articles = models.IntegerField(default=0, null=False)

我想写一个Django查询,说明给我所有条件匹配这个PostGres WHERE子句的对象

WHERE num_negative_articles / (num_negative_articles + num_positive_articles) > .95

但是我在编写Django查询表达式时遇到了麻烦,因为通常它只允许单个字段,例如

DomainTrackerStat.objects.filter(num_negative_articles__gt=.95)

如何编写这个更复杂的查询?

python sql django python-3.x where
2个回答
2
投票

F()表达式可用于在模型字段之间执行算术运算(+, - ,*等),以便在它们之间定义代数查找/连接。

F()对象表示模型字段或带注释的列的值。它可以引用模型字段值并使用它们执行数据库操作,而无需将它们从数据库中拉出到Python内存中。

data = DomainTrackerStat.objects.annotate(result=F('num_negative_articles') / (F('num_negative_articles') + F('num_positive_articles'))).filter(result__gt=0.95)

现在,数据中的每个项目都有一个名为“result”的额外列,其中包含“num_positive_articles”和“num_negative_articles”的乘积,分别除以每个项目的“num_negative_articles”。

Documentation供进一步参考


0
投票

您可以在查询集中注释数学表达式的值,然后按该注释值进行过滤:

DomainTrackerStat.objects.annotate(value=F('num_negative_articles') / (F('num_negative_articles ') + F('num_positive_articles'))).filter(value__gt=0.95)
© www.soinside.com 2019 - 2024. All rights reserved.