我正在尝试在django中显示聊天日志。使用下面的查询,我可以按正确的顺序获取整个聊天日志。
latest_chats_list = Chat.objects.order_by('timestamp')我想要这一行的功能(顺序中的最后10个元素),但是django不允许负索引。
latest_chats_list = Chat.objects.order_by('timestamp')[-10:]如果我尝试这一行,我得到我想要的消息,但它们的顺序是错误的。
latest_chats_list = Chat.objects.order_by('-timestamp')[:10]这一行给出了前10次聊天,而不是最近的一次。
latest_chats_list = Chat.objects.order_by('-timestamp')[:10].reverse()发布于 2015-07-19 05:07:08
last_ten = Chat.objects.all().order_by('-id')[:10]
last_ten_in_ascending_order = reversed(last_ten)编辑(来自评论)
为什么不使用姜戈的queryset.reverse()呢?
因为它会扰乱SQL查询,就像queryset.order_by()一样。对查询集([:10])进行切片也会改变SQL查询,向其添加LIMIT和OFFSET。两者可以以意想不到的方式结合在一起……
另一方面,内置的Python函数reversed(iterable)只改变了查询集的迭代方式,根本不影响SQL。
https://stackoverflow.com/questions/31495586
复制相似问题