Subtracting two annotated columns

我只是一个虾纸丫 提交于 2019-11-29 13:07:45

Actually,

c = c.annotate(variance=F('metric')-F('metric_prior'))

works as you would like it to starting with Django 1.8.

Moreover, you can also order by an expression, which means you can just use:

c = c.order_by(F('metric') - F('metric_prior'))

or even just:

c = c.order_by(Sum('results__metric') - Sum('results__metric_prior'))

Ticket is there for more than 4 years (by 2014), but it can be accomplished with a little .extra() query, like this:

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

Yes, it can be a bit unpredictable with different DBMS. But if you limit the syntax inside extra to very common SQL it should work more or less everywhere.

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!