Django – 时区问题

Django 2.x关于时区有2个配置项:

  • TIME_ZONE
  • USE_TZ

Django在这块设计主要是考虑到了国际化问题,所以初衷是希望在数据库里统一按UTC时区保存时间。

可惜,我就是希望数据库里是本地时间保存,或者说我不希望受到Django设计的约束。

前提

大家必须明确2个概念。

操作系统底层提供给应用的永远是UNIX时间戳,这个与任何时区无关。

UNIX时间戳只有根据时区,才能格式化出正确的时间字符串。

解决方法

设置正确的TIME_ZONE

怎么办呢?

首先,必须设置TIME_ZONE=’Asia/Shanghai’,因为Django会将该设置生效到python的datetime模块内部,将会覆盖datetime的默认时区配置(来自操作系统的)。

具体代码在 django/conf/__init__.py中:

从代码可见,django通过time.tzset()影响了datetime模块的默认时区,如果我们不正确设置就会导致datetime模块永远无法得到正确的本地时间。

因此,你总是应该先设置正确的时区,这个不需要考虑USE_TZ如何。

设置USE_TZ=False

当我们USE_TZ=True的时候,Django只会使用datetime内的UNIX时间戳,按照UTC时区格式化成时间字符串,保存到数据库。同时,当从数据库读取时间字符串的时候也会按UTC时区还原为UNIX时间戳。

因此,我们要设置USE_TZ=False,才能让Django利用TIME_ZONE时区格式化字符串保存到数据库,同样的读取数据库时Django会按TIME_ZONE时区还原为UNIX时间戳。

总结

TIME_ZONE总是应该设置为本地时区。

USE_TZ=True则数据库总是按UTC时区格式化,USE_TZ=False则数据库按TIME_ZONE时区格式化,最终在内存中表现是一致的。

如果文章帮助您解决了工作难题,您可以帮我点击屏幕上的任意广告,或者赞助少量费用来支持我的持续创作,谢谢~