我有一个模型,它有两个字段日期和类型:
class Obj(Model):
date = DateTimeField
type = ChoiceField我想按它们的创建日期对它们进行排序,但是我希望将相同类型的对象粘合在一起:
BLUE
当我命令它时,我希望它先查看日期,得到最近的日期,然后接受所有对象类型的对象,并将它们按照日期顺序排列,然后取第二个类型的下一个日期,并将它们放在上一个日期之后的顺序中:
命令:
GREEN
所以我想要的基本上是order_by标题,然后按日期排列组--我可以做一些琐碎的事情吗?还是我必须去处理一下--如果我可以避免原始SQL,最好是避免使用原始SQL,因为这是分页的。
朴素的方法order_by("type", "date")将产生类似于我想要的结果的结果,但它不是按查询集中的日期排序,而是先按类型排序,所以它将类型的顺序作为主排序。其结果是:
BLACK
发布于 2022-07-13 15:56:31
是的,我想我有一个有用的答案--你需要使用Subquery和OuterRef。第一个查询集按您想要但使用OuterRef过滤的日期对所有Obj模型进行排序-- OuterRef从第二行获取类型字段。
然后,第二行使用第一行的子查询执行注释,.values('date')[:1]将获得最后一个日期值(您可能希望更改该值)。注释意味着每个对象都被标记为创建该类型的最新对象的日期。
from django.db.models import OuterRef, Subquery
dates = Obj.objects.filter(type=OuterRef('type')).order_by('-date')
Obj.objects.annotate(
newest_creation=Subquery(dates.values('date')[:1])
).order_by('date', 'newest_creation')您可能需要更改日期和newest_creation的顺序,以获得所需的排序。
https://stackoverflow.com/questions/72968308
复制相似问题