注意:作者懶癌發(fā)作,可能寫反了。請讀者參照評論進行修改。
auto_now
與 auto_now_add
是Django 的 models 中,關(guān)于時間的兩個屬性參數(shù)。比如可以用在 DateField()
或者 DateTimeField()
的屬性中。
1 auto_now 與 auto_now_add 的比較
-
auto_now=True
表示某個字段(或者對象)第一次保存的時候,由系統(tǒng)生成的。自動繼承了不可更改的屬性editable=False
,所以一旦設(shè)定就不可以更改、不可以再次重載(override),因此在后臺 admin 中也不會顯示出來。通常可以用在注冊時間、生成時間等字段。 -
auto_now_add=False
是字段每次修改的時候,最新的時間都會保存進去。
使用示例,對于一個評論的 models, timestamp 是首次發(fā)表時間,updated 是最新編輯成功的時間:
from django.db import models
def comment(models.Model):
timestamp = models.DateTimeField(auto_now_add=True, auto_now=False)
updated = models.DateTimeField(auto_now_add=False, auto_now=True)
注意
-
auto_now
與auto_now_add
不能同時為 True,在之前的Django版本,如果兩者同時為空會拋異常。
2 使用情況考慮
auto_now
與 auto_now_add
從 Django 1.4.5 開始就相當于使用了 timezone.now()
,而不是 datetime.now()
。
Django 與 pytz 的建議,如果對時間的準確度有相當高的要求(比如涉及到錢的情況),最好是把時間對象存儲為 UTC 時間(全球標準時間,即格林威治時間),然后用戶使用時再轉(zhuǎn)化成本地時間(與時區(qū)相關(guān))。
Django 的時間依賴于 pytz 包,但是在 Django 1.11 之前,Django 會查看是否存在 pytz 包,然后去使用該包的時區(qū)數(shù)據(jù)庫。在 Django 1.11 以后,pytz 是默認隨著 Django 一起安裝了,但是 Django 的 settings.py 中,USE_TZ=False
是關(guān)閉的,要使用時區(qū)時,需要自己去打開。
參考
Django官方文檔:DateField.auto_now 與 DateField.auto_now_add
stackoverflow: Django auto_now and auto_now_add
pytz - World Timezone Definitions for Python
stackoverflow: How django time zone works with model.field's auto_now_add