自动更新字段的最佳做法是什么?

Lin*_*htz 1 python django

这是我要完成的工作:我的模型中有一个“年龄”字段,我希望它的值是直到现在为止的持续时间-我的意思是现在是实时的,而不仅仅是obj创建时间或更新时间时间。

最初,我想知道django中是否存在某种动态字段,该字段值将仅基于公式进行更新。但是后来我发现这是不现实的,必须在某个时间点对其进行更新。

现在,我想到的是编写一个模型方法来计算值并将其分配给字段,并在每次查询类对象之前手动调用它并将新值写入字段。

我想知道有没有更好的方法可以完成此操作,因为我的方法会给数据库增加一些负担,而这可能只是不必要的。

谢谢你的帮助。

Dan*_*man 6

这确实是错误的方法。您应该在数据库中存储一个静态值,即准确地创建或更新时间,然后在需要时通过Python方法得出年龄。例如:

class MyModel(models.Model):
    updated_at = models.DateTimeField(auto_now=True)

    @property
    def age(self):
        return (datetime.datetime.now() - self.updated_at).seconds   # or whatever units
Run Code Online (Sandbox Code Playgroud)