python timestamp类型_postgresql的timestamp类型与python的datetime类型之间的坑

本文通过实例分析了Python中timestamp类型与PostgreSQL的timestamp类型在不同时区设置下转换存在的问题,强调了使用datetime.now(tz=timezone.utc)获取带时区时间以及PostgreSQL使用timestampz类型的重要性,以确保数据一致性。
摘要由CSDN通过智能技术生成

最近的项目突然发现一个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 =

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值