pgsql中epoch用法


问题描述

提示:这里描述项目中遇到的问题:

昨天又被叫回来加班,説是数据问题,又回来加班搞,到了以后发现数据没问题,那就是查询接口的事了,写查询接口的人用时间戳去查询,明明直接可以直接用日期查询,非得改成时间戳查询,结果还是有问题,接下来复盘一下问题。

先看下extract函数格式

c 复制代码
extract (field from source)
extract函数是从日期或者时间数值里面抽取子域,比如年、月、日等。source必须是timestamp、time、interval类型的值表达式。field是一个标识符或字符串

epoch 新纪元时间的使用

c 复制代码
新纪元时间 Epoch 是以 1970-01-01 00:00:00 UTC 为标准的时间,将目标时间与 1970-01-01 00:00:00
时间的差值以秒来计算 ,单位是秒,可以是负值; 有些应用会将时间存储成epoch 时间形式,以提高读取效率,

实现sql:

c 复制代码
其中:indate是test表中的字段,类型为:timestamp
select extract(epoch from indate),indate from test ;

执行结果

我们以2024-01-06 08:00:00 为例,可以看到下列图中对应的时间戳是 :1704528000

我们看java中计算到的时间戳

c 复制代码
String time = "2024-01-06 08:00:00";
SimpleDateFormat formatTime = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
Date parseTime = formatTime.parse(time);
System.out.println("------------" + parseTime.getTime());
得到的结果:1704499200000,对应sql执行结果:2024-01-06 00:00:00

解决方案:

可以看出sql是有八小时时间差,通过以下方式实现:

c 复制代码
select extract(epoch from cast(indate - interval '8hour' as TIMESTAMP))  from test ;
相关推荐
睡不醒男孩03082311 小时前
第七篇:揭秘 PostgreSQL 数据库内核级管控:CLup 深度架构设计与高可用底座技术白皮书
数据库·postgresql·clup
医疗信息化王工16 小时前
医院自律端系统——预警处置模块全栈实战(ASP.NET Core + Vue3 + Quartz 定时调度)
mysql·postgresql·vue·asp.net core·quartz
IvorySQL16 小时前
PostgreSQL 技术日报 (6月9日)|PL/SQL 迁移自动化,前沿峰会即将启幕
sql·postgresql·自动化
睡不醒男孩03082316 小时前
第八篇:如何构建一站式 PostgreSQL 性能优化与智能管控平台?从盲目排查到 CLup 自动化运维演进
运维·postgresql·性能优化
睡不醒男孩03082316 小时前
第五篇:2026年企业级 PostgreSQL 高可用方案深度横评:Patroni vs. CLup 架构与可靠性全面对决
数据库·postgresql·架构
哭哭啼18 小时前
pgSql 事务篇
java·数据库·postgresql
snow@li19 小时前
数据库:MySQL vs PostgreSQL 详尽对比(2026版)
java·mysql·postgresql
J.Kuchiki19 小时前
【PostgreSQL 内核学习:平衡 K 路归并(Balanced k-way Merge)】
数据库·学习·postgresql
lvbinemail19 小时前
【无标题】
数据库·postgresql·zabbix·监控
岳麓丹枫00121 小时前
PG数据库无法接受连接问题分析定位
数据库·postgresql