给定 django 模型 A 和 B:
class A(models.Model):
things = models.ManyToManyField('B')
class B(models.Model):
score = models.FloatField()
text = models.CharField(max_length=100)
如何获取 A
的列表? text
订购的实体得分最高的 B
在things
?
最佳答案
这种事情真的很难。如果您想按分数排序,聚合可以帮助您:
from django.db.models import Max
A.objects.annotate(highest_b=Max(B__score)).order_by('highest_b')
但实际上您想要执行两个操作:按最高分数聚合,然后按具有该分数的项目的文本排序。无论您使用哪种语言,这都是棘手的。我已经写过关于这个问题的文章 on my blog - 出于您的目的,我认为通过 .raw()
方法在 SQL 中执行此操作可能是最简单的。
关于python - Django:按多对多关系的字段排序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4309062/