程序问答   发布时间:2022-06-02  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了django-通过计算字段对queryset排序大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。

如何解决django-通过计算字段对queryset排序?

开发过程中遇到django-通过计算字段对queryset排序的问题如何解决?下面主要结合日常开发的经验,给出你关于django-通过计算字段对queryset排序的解决方法建议,希望对你解决django-通过计算字段对queryset排序有所启发或帮助;

如果你不介意进行逻辑复制,则可以执行以下操作:

Foo.objects.extra(select={'d_fIEld': 'A - B'}).extra(order_by=['d_fIEld'])

解决方法

我想要一个带有计算字段的模型,可以将其应用于排序。例如,假设我有以下模型:

class Foo(models.Model):
    A = models.IntegerField(..)
    B = models.IntegerField(..)
    C = models.ForeignKey(..)

我想要一个D和E字段,这些字段由以下公式计算得出:

  1. D = A-B
  2. E = A-X(其中X是模型C相关记录的字段)
    如果我不需要应用排序,则实现此操作将很简单。我只是将属性添加到模型类。但是,我需要按这些字段排序。

一种解决方案是将所有记录提取到内存中并在那里进行排序,我认为这是不得已的方法(这会破坏有关分页的内容)。

有没有办法实现我正在尝试的?任何指导表示赞赏。

编辑:非规范化是行不通的。字段X的值非常频繁地更改,并且许多Foo记录与模型C的一条记录有关。X的更新将需要E的数千次更新。

大佬总结

以上是大佬教程为你收集整理的django-通过计算字段对queryset排序全部内容,希望文章能够帮你解决django-通过计算字段对queryset排序所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。
标签: