我正在尝试将DateTimeField添加到我的django模型中,并将最大时间戳作为默认值。我已经发现,Django中的最大时间戳是9999/12/31 23:59:59,这与我的postgres DB中使用的最大时间标记不同。当使用此时间戳作为字段的默认值时,我会得到一个OverflowError: date value out of range
错误。因此,我在9999年1月1日00:00:00这样尝试了同样的方法:
start_time = models.DateTimeField(null=False, default=datetime.datetime(9999,01,01,00,00,00,tzinfo=utc))
现在,当我将这种向南迁移应用于数据库时,我得到以下异常:
RuntimeWarning: DateTimeField received a naive datetime (9999-01-01 00:00:00) while time zone support is active.
当查看数据库时,我发现我的本地时区已应用于默认值:9999-01-01 00:00:00+01
。这让我得出结论,django不知何故忽略了时区意识,但我不知道为什么会这样。
附加信息:
Django TIME_ZONE设置为"欧洲/柏林"
USE_TZ是真正的
感谢您的帮助。
尝试在datetime上调用replace
,而不是将tzinfo传递到datetime的__init__
。取自django文档:
import datetime
from django.utils.timezone import utc
now = datetime.datetime(9999, 1, 1).replace(tzinfo=utc)