gpt4 book ai didi

django - 按 created_at date Django 排序

转载 作者:行者123 更新时间:2023-12-02 04:38:33 25 4
gpt4 key购买 nike

我试图按创建日期/时间对该模型中的“记录”进行排序,但遇到了问题。

class MyModel(models.Model):     
created_at = models.DateTimeField(auto_now_add=True)

class Meta:
order_with_respect_to = 'created_at'

当我尝试运行 syncdb 时出现以下错误

AttributeError: 'NoneType' object has no attribute 'to'

感谢任何帮助

最佳答案

这不是 order_with_respect_to 的用途 - 它用于将模型标记为相对于相关模型已订购。就我个人而言,我从来没有机会使用它,所以我不能根据经验谈论它——只能说这不是你进行简单日期排序的方式。

要按创建时间排序,请使用 ordering meta 属性代替:

 class MyModel(models.Model):
created_at = models.DateTimeField(auto_now_add=True)

class Meta:
ordering = ['created_at']

严格来说,您不必声明这一点。如果您未在模型或查询中声明任何其他顺序,则结果将按其 PK 排序。默认情况下,PK 将是一个自动递增的系列,因此对象将按其创建顺序隐式排序。但是,如果您真的关心排序顺序,最好明确说明而不是依赖升序 PK 的副作用。

关于django - 按 created_at date Django 排序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21395462/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com