在 Django 1.11 中,我有一个简化如下的父子模型(一对多关系):

class Conversation(models.Model):
  name = models.CharField(max_length=150)

class Comment(models.Model):
  comment_text = models.TextField()
  submitted_date = models.DateTimeField()
  conversation = models.ForeignKey(Conversation, on_delete=models.CASCADE)

  class Meta:
    ordering = ['-submitted_date']

一个对话可以有很多评论。现在我想要做的是对有最新评论的对话进行排序。我试图将其添加到对话模型中:
class Meta:
  ordering = ['-comment__submitted_date']

并且这种工作,但它在查询集中返回重复项 - 这种重复行为在 Django 中有详细记录以及它发生的原因 - https://docs.djangoproject.com/en/1.11/ref/models/querysets/#order-by - 但它没有说明如何解决它。

我正在寻找一种方法来解决此限制。总体目标是:按最近的评论 (submitted_date) 对对话进行排序。我尝试了多种变体,但它要么根本不排序,要么返回重复项(这对我没用)。 distinct() 也不起作用,链接中也记录了这一点。

我可以在 Conversation 中添加一个“updated_at”或类似的字段,并在创建/更新评论时更新它,但这对我来说真的很讨厌和不干净,我宁愿尽可能避免它。

有什么建议么?

最佳答案

我认为一种方法是找到每个对话的最后一条评论的日期,然后按日期排序

Conversation.objects.annotate(last_comment=Max('comment__submitted_date')) \
                    .order_by("last_comment")

关于python - Django 1.11 order by field on related model 重复结果解决方法,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/47212257/

10-16 18:46