按日期查询Django ORM排序的唯一文本消息对象

我的短信模型如下:

    class TextMessage(models.Model):
        from_phone_number = models.CharField(max_length=25)
        to_phone_number = models.CharField(max_length=25)
        date_of_message = models.DateTimeField(auto_now_add=True)
        message_body = models.TextField()

我正在尝试返回Django查询集(它必须为查询集),其中 from_phone_numbers 是唯一的 AND 文本消息是最近的短信。例如,如果我有短信:

**id**| **from_phone_num** | **to_phone_num** | **date_of_message**|  **Message body** |  
7;"19991112222";"19996667777";"2019-11-13 15:07:53.726911-07";"dupe message 2";
4;"19993334444";"19996667777";"2019-11-13 13:50:05.921257-07";"dsfsdfsf";  
3;"19992222222";"19995552323";"2019-11-13 13:49:18.503679-07";"TEST123";
5;"19991112222";"19996667777";"2019-11-13 15:07:21.834347-07";"dupe message 1";

返回的查询集为:

**id**| **from_phone_num** | **to_phone_num** | **date_of_message**|  **Message body** |  
7;"19991112222";"19996667777";"2019-11-13 15:07:53.726911-07";"dupe message 2";
4;"19993334444";"19996667777";"2019-11-13 13:50:05.921257-07";"dsfsdfsf";  
3;"19992222222";"19995552323";"2019-11-13 13:49:18.503679-07";"TEST123";

这是我已经尝试过的查询:

TextMessage.objects.order_by('date_of_message','from_phone_number').distinct('date_of_message','from_phone_number')

但是它没有给我预期的结果。任何帮助将不胜感激!

xlccy 回答:按日期查询Django ORM排序的唯一文本消息对象

尝试以下查询。

 TextMessage.objects.order_by('from_phone_number','-date_of_message').distinct('from_phone_number')
  

DISTINCT ON表达式必须与最左边的ORDER BY匹配   表达式。因此,通过将您在distinct中用作   order_by的第一列应该起作用。

本文链接:https://www.f2er.com/3100292.html

大家都在问