4

我有一个这样的模型 Django 模型:

class MyModel(models.Model):
  fieldA = models.CharField(max_length=100)
  fieldB = models.IntegerField()
  fieldC = models.IntegerField()

我想找到 Max(fieldB + fieldC)。有没有 Django 方法可以做到这一点?还是我必须使用原始 sql(以防它类似于“从 mymodel_table 中选择 Max(fieldA + fieldB)”)?

提前致谢

4

1 回答 1

7

这是一个应该工作的相当迂回的解决方案,改编自带有表达式的 Django 聚合查询

MyModel.objects.extra(select={'sum':'fieldB + fieldC'}).order_by('-sum')[0]

原始无效答案(从 Django 1.4 开始,F() 表达式在注释中不起作用)

您可以使用F() 表达式注释/聚合来为您执行此操作。我想你想要的是。

from django.db.models import F, Max
MyModel.objects.annotate(sum=F('fieldB') + F('fieldC')).aggregate(Max('sum'))
于 2012-11-20T16:05:19.153 回答