首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >如何在保持对象按其他字段分组的同时排序查询集?

如何在保持对象按其他字段分组的同时排序查询集?
EN

Stack Overflow用户
提问于 2022-07-13 14:50:57
回答 1查看 44关注 0票数 1

我有一个模型,它有两个字段日期和类型:

代码语言:javascript
运行
复制
class Obj(Model):
    date = DateTimeField
    type = ChoiceField

我想按它们的创建日期对它们进行排序,但是我希望将相同类型的对象粘合在一起:

BLUE

  • 02.01.2022 BLACK

  • 03.01.2022 BLUE

  • 04.01.2022 GREEN

  • 05.01.2022 BLUE

  • 06.01.2022 BLACK

  • 07.01.2022
  • 01.01.2022绿色

当我命令它时,我希望它先查看日期,得到最近的日期,然后接受所有对象类型的对象,并将它们按照日期顺序排列,然后取第二个类型的下一个日期,并将它们放在上一个日期之后的顺序中:

命令:

GREEN

  • 04.01.2022 GREEN

  • 06.01.2022 BLACK

  • 02.01.2022 BLACK

  • 05.01.2022 BLUE

  • 03.01.2022 BLUE

  • 01.01.2022

  • 07.01.2022

所以我想要的基本上是order_by标题,然后按日期排列组--我可以做一些琐碎的事情吗?还是我必须去处理一下--如果我可以避免原始SQL,最好是避免使用原始SQL,因为这是分页的。

朴素的方法order_by("type", "date")将产生类似于我想要的结果的结果,但它不是按查询集中的日期排序,而是先按类型排序,所以它将类型的顺序作为主排序。其结果是:

BLACK

  • 02.01.2022 BLACK

  • 05.01.2022 BLUE

  • 03.01.2022 BLUE

  • 01.01.2022 BLUE

  • 07.01.2022 GREEN

  • 04.01.2022

  • 06.01.2022绿色
EN

回答 1

Stack Overflow用户

发布于 2022-07-13 15:56:31

是的,我想我有一个有用的答案--你需要使用Subquery和OuterRef。第一个查询集按您想要但使用OuterRef过滤的日期对所有Obj模型进行排序-- OuterRef从第二行获取类型字段。

然后,第二行使用第一行的子查询执行注释,.values('date')[:1]将获得最后一个日期值(您可能希望更改该值)。注释意味着每个对象都被标记为创建该类型的最新对象的日期。

代码语言:javascript
运行
复制
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的顺序,以获得所需的排序。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/72968308

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档