postgrel 时区问题 8小时

1.查看数据库时区

数据库查看时区

show time zone;

如果发现自己的时区是对的,那就跳过修改时区这一步。

数据库设置成东八区 北京时间 UTC+8

set time zone 'PRC';

2.遇到的问题

我遇到的问题是,导出excel后表格中的时间不对

数据库查询时间:正常

在这里插入图片描述

后台查询时间:正常 (因为后端设置过时区,设置方法:点这里)
在这里插入图片描述

导出excel接口返回的数据:正常
在这里插入图片描述

但是导出excel表中的数据:错误
在这里插入图片描述

3.问题分析

一直到最后一步,后台将正确数据传给excel才发生错误。
因为timestamp不带时区,从postgresql中提取出标准时间(TIMESTAMP)转换为unix时间戳的时候,pg默认把这个标准时间是当做格林尼治时间处理的,格林尼治时间要比东八区时间慢8个小时。

解决问题:
因为是timestamp 转化后出现的问题,所以不如让他不进行转换,直接在数据库查询时,将它变为varchar类型。

在这里插入图片描述

4.问题解决

时间正常显示
在这里插入图片描述

  • 3
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

qiweilong123456

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值