在Django中由.annotate()创建的字段上使用.extra() [英] Using .extra() on fields created by .annotate() in Django

查看:1144
本文介绍了在Django中由.annotate()创建的字段上使用.extra()的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我想为表中的每个对象检索两个字段(它们是聚合本身)的总和。



以下可能会更好地描述我m后,导致字段列表中的未知列 -Error:

  items = MyModel.objects.annotate(
field1 = Sum(relatedModel__someField),
field2 = Sum(relatedModel__someField))extra(
select = {sum_field1_field2我还尝试使用F()进行字段查找,但是这给了我一个无效的sql语句。



非常感谢任何有关如何解决这个问题的想法。

解决方案

这是你想要的?

  items = MyModel.objects.extra(
select = {'sum_field1_field2':'SUM(relatedModel__someField)+ SUM(relatedModel__someField)'},


I want to retrieve a sum of two fields (which are aggregations themselves) for each object in a table.

The following may describe a bit better what I'm after but results in an Unknown column in field list-Error:

items = MyModel.objects.annotate(
                field1=Sum("relatedModel__someField"),
                field2=Sum("relatedModel__someField")).extra(
                        select={"sum_field1_field2": "field1 + field2"})

I also tried using F() for the field lookups but that gives me an invalid sql statement.

Any ideas on how to solve this are much appreciated.

解决方案

it this what you want?

items = MyModel.objects.extra(
    select = {'sum_field1_field2': 'SUM(relatedModel__someField) + SUM(relatedModel__someField)'},
)

这篇关于在Django中由.annotate()创建的字段上使用.extra()的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆