最近的项目突然发现一个bug,就是当服务器系统时区是utc时区,而服务器pgsql的时区是+8时区时候,通过python的datetime.now()插入的timestampz值有问题。所以特意做了一个测试。
1 测试前提
1.1 python的datetime类型
首先,要了解python的datetime类型是包括时间与时区的。而通过datetime.now()与datetime.utcnow()获得的时间其tzinfo属性为null,即不带时区属性。要想获得带时区属性的datetime类型,就必须使用datetime.now(tz=timezone.utc)或者datetime.now(tz=timezone(timedelta(hours=8)))。
1.2 pgsql的时间戳类型
然后,pgsql的时间戳类型包括timestamp(无时区), timestampz(有时区)两种。
1.3 测试表与测试代码
为了进行测试,我新建了一张time_test表,然后分别插入pythono的datetime.now(), datetime.utcnow(), datetime.now(timezone.utc)三个值。
#!/usr/bin/env python
# -*- coding: utf-8 -*-
import psycopg2
import logging
from datetime import datetime
from datetime import timezone
def insert():
now = datetime.now()
utcnow =