kam*_*nga 5 django django-models
我有一个Comment模型。它具有以下时间戳字段:
created = models.DateTimeField(auto_now_add=True, blank=True, null=True)
last_edit = models.DateTimeField(auto_now=True, blank=True, null=True)
Run Code Online (Sandbox Code Playgroud)
现在,当我使用这种格式更新评论时:Comment.objects.filter(...).update(text="some new text"),该last_edit字段不会更新,而评论的文本会更新。有什么问题?
更新:另外,我正在使用filter因为update不适用于get,即 Comment.objects.get(...).update(...)无法使用。我真正想做的是get因为我确信一次只需要更新一条评论。
因为您使用的是update,它直接在数据库中进行更新,而auto_now在 Python 中完成。这会起作用:
for commment in Comment.objects.filter(...):
comment.text="some new text"
comment.save()
Run Code Online (Sandbox Code Playgroud)
显然,这比在数据库中一次性完成的效率低。如果您真的需要它,那么您还必须在更新中设置日期:
Comment.objects.filter(...).update(text="some new text", last_edit=datetime.datetime.now())
Run Code Online (Sandbox Code Playgroud)