django-通过计算字段对queryset排序
我想要一个带有计算字段的模型,可以将其应用于排序。例如,假设我有以下模型:
class Foo(models.Model): A = models.IntegerField(..)
B = models.IntegerField(..)
C = models.ForeignKey(..)
我想要一个D和E字段,这些字段由以下公式计算得出:
- D = A-B
- E = A-X(其中X是模型C相关记录的字段)
如果我不需要应用排序,则实现此操作将很简单。我只是将属性添加到模型类。但是,我需要按这些字段排序。
一种解决方案是将所有记录提取到内存中并在那里进行排序,我认为这是不得已的方法(这会破坏有关分页的内容)。
有没有办法实现我正在尝试的?任何指导表示赞赏。
编辑:非规范化是行不通的。字段X的值非常频繁地更改,并且许多Foo记录与模型C的一条记录有关。X的更新将需要E的数千次更新。
回答:
如果你不介意进行逻辑复制,则可以执行以下操作:
Foo.objects.extra(select={'d_field': 'A - B'}).extra(order_by=['d_field'])
以上是 django-通过计算字段对queryset排序 的全部内容, 来源链接: utcz.com/qa/431363.html