PostgreSQL常用时间函数与时间计算提取示例说明

news2024/11/21 10:54:08

文章目录

  • 常用函数与常量
  • to_timestamp(字符串转时间戳、数字转时间戳)
  • date与to_date(字符串转日期、时间戳转日期)
  • interval(时间计算)
    • 基本操作与格式
    • 混合运算
  • to_char(各种时间转字符串)
  • extract(提取时间字段,年月日时分秒,周、季度,第几周、第几天)
    • 基本说明
    • 常用时间字段
    • 其他时间字段
  • date_part(类似extract)
  • date_trunc(时间截断,计算特殊时间,一年第1天,一个季度第1天,一周最后1天等)
  • 综合应用-时间计算
    • 时间差
    • 时间加减
  • 日期时间格式化字符串
    • 常用格式化字符
    • 其他格式化字符

常用函数与常量

函数说明
current_time现在的时间
current_date今天的日期
current_timestamp当前日期和时间
now()当前的日期和时间和current_timestamp一样
localtimetime,当前时间
localtimestamp当前日期和时间
timeofday()字符串,当前日期和时间
age(timestamp1, timestamp2)计算年纪,timestamp1-timestamp2,结果类型是interval,类似于:29 years 9 mons 27 days
select current_date,current_time,current_timestamp,now(),localtime,localtimestamp,timeofday();

PostgreSQL常用时间变量

select age('2030-04-10', '2000-06-13');

第1个参数减第2个参数,age返回值是interval,很方便算年龄

PostgreSQL age函数

-- 时间戳转字符串再截取
SELECT now()::timestamp,substring(''||now()::timestamp from 1 for 19);

PostgreSQL时间截取

to_timestamp(字符串转时间戳、数字转时间戳)

函数说明
to_timestamp(text, text)把字串转换成时间戳
to_timestamp(double)把数字转时间戳
select to_timestamp(1859351600),to_timestamp('1859351600'::bigint),to_timestamp('2090 01 12', 'YYYY MM DD');

PostgreSQL转时间戳

想要了解YYYY MM DD代表什么,可以参考后文:日期时间格式化字符串

date与to_date(字符串转日期、时间戳转日期)

函数说明
to_date(text, text)字串转日期,第1个参数是时间,第2个参数是格式化字符串
date(timestamp)时间戳转日期
date(text)字符串转日期
select to_date('2090 01 12', 'YYYY MM DD'),date(now()),date('2090-09-28');

PostgreSQL to_date函数

在一些喜欢用字符串存时间的计算时非常有用,虽然不推荐在数据库上做计算,但是有时候有些特殊的项目,需要存储过程,这些函数能极大的简化计算。

例如,有些每日都要和前一日比(这里简化了只计算了日期):

select priceday,to_char(to_date(priceday, 'YYYYMMDD')-interval '1 day','YYYYmmdd') as lastDay from elt_data_table;

interval(时间计算)

interval还是非常有用,不仅仅可以用来表示时间差,还可以用来做时间计算。

基本操作与格式

操作符说明
year
month
day
hour小时
min分钟
sec

加不加s不影响,interval '2 day’和interval '2 days’都可以。


select now(),now() - interval '1 day' as subday,
now() + interval '1 week' as addweek,now() - interval '1 month' as submonth,now()+interval '1 year' as addyear;
 
--加1年1月1天1时1分1秒
select now() + interval '1 year 1 month 1 day 1 hour 1 min 1 sec';

PostgreSQL interval函数

混合运算

interval还可以执行乘除运算:

select interval '1 day' + interval '1 hour' as addmod,
interval '1 day' - interval '1 hour' as submod,
interval '1 hour' * double precision '3.5' as mulmod,
interval '1 hour' / double precision '1.5' as divmod,
current_time - interval '2 hours' as sub2h,
current_date - interval '3 days' as sub3d,
current_timestamp + interval '2 years' as add2y;

PostgreSQL 时间混合计算

to_char(各种时间转字符串)

这里我们只看to_char转日期时间的部分

第2个参数都是格式化字符串,关于日期时间部分可以参考后文:日期时间格式化字符串

函数说明
to_char(timestamp, text)把时间戳转换成字串
to_char(interval, text)把时间间隔转为字串
to_char(date, text)把时间间隔转为字串
to_char(int, text)把整数转换成字串
to_char(double precision, text)把实数/双精度数转换成字串
to_char(numeric, text)把numeric转换成字串
select
to_char(current_timestamp,'YYYY/mm/dd HH24:MI:SS'),
to_char(current_date,'YYYYmmdd'),
to_char(interval '15h 2m 12s', 'HH24:MI:SS');

PostgreSQL日期格式化

extract(提取时间字段,年月日时分秒,周、季度,第几周、第几天)

基本说明

函数说明
extract(field from timestamp)获取时间戳字段
extract(field from date)获取date字段
extract(field from interval)从interval获取时间字段
select current_date,
extract(year from current_date) as dyear,
extract(month from current_date) as dmonth,
extract(day from current_date) as dday,
-- 时分秒这种只能从包含时间的数据取,例如timestamp
extract(hour from current_timestamp) as dhour,
extract(minute from current_timestamp) as dminute,
extract(second from current_timestamp) as dsecond,
extract(week from current_date) as dweek,
extract(quarter from current_date) as dquarter;

PostgreSQL 时间字段提取

select current_timestamp as dtime,extract(epoch from current_timestamp) as depoch;

-- 计算年龄
SELECT extract(year from age(TIMESTAMP '2030-07-08',TIMESTAMP '2000-07-07'));
-- 计算相差月份
select extract(year from age(TIMESTAMP '2030-11-05',TIMESTAMP '2010-02-04')) * 12 + extract(MONTH from age(TIMESTAMP '2030-11-05',TIMESTAMP '2010-02-04'));

常用时间字段

不区分大小写

时间字段说明
YEAR年份
MONTH月份,timestamp月份数(1-12),interval月份数(0-11)
DAY几号
HOUR小时域(0-23)
MINUTE分钟(0-59)
QUARTER季度(1-4)
SECOND秒(0-59)
WEEK该年第几周
EPOCH数字时间戳,1731315752.861393

其他时间字段

时间字段说明
DOY一年的第几天(1-365/366)
DOW星期几(0-6,星期天是0)
MILLISECONDS毫秒
MICROSECONDS微秒
CENTURY世纪
DECADE十年,年份除以10
MILLENNIUM千年

date_part(类似extract)

基本和extract等价

函数说明
date_part(text, timestamp)从时间戳提取时间字段
date_part(text, date)从日期提取时间字段
date_part(text, interval)从interval提取时间字段
select 
date_part('year',current_date) as dyear,
date_part('month',now()) as dmonth,
date_part('day',now()) as dday,
date_part('week',now()) as dweek,
date_part('quarter',now()) as dquarter;

PostgreSQL时间提取函数date_part

date_trunc(时间截断,计算特殊时间,一年第1天,一个季度第1天,一周最后1天等)

主要用于计算一些特殊时间,

函数说明
date_trunc(text, timestamp)截断成指定的精度,第1个参数指定精度
select date_trunc('year',now()) as 当年第1,
date_trunc('year',now() + interval '1 year') - interval '1 day' as 当年最后1,
date_trunc('month',now()) as 当月第1,
date_trunc('month',now() + interval '1 month') - interval '1 day' as 当月最后1,
date_trunc('quarter',now()) as 当季度第1,
date_trunc('quarter',now() + interval '3 month') - interval '1 day' as 当季度最后1,
date_trunc('week',now()) as 当周第1,
date_trunc('week',now() + interval '1 week') - interval '1 day' as 当周最后1;

PostgreSQL时间截取函数

综合应用-时间计算

时间差


-- 59只取分钟部分
select date_part('minute',cast('2050-01-01 14:00:00' as TIMESTAMP)-cast('2050-01-01 13:00:10' as TIMESTAMP));


select round(date_part('epoch', TIMESTAMP '2050-05-05 14:00:00' - TIMESTAMP '2050-05-05 13:10:10')) as dsec,
round(date_part('epoch', TIMESTAMP '2050-05-05 14:00:00' - TIMESTAMP '2050-05-05 13:10:10')/60) as dmin,
round(date_part('epoch', TIMESTAMP '2050-05-05 14:00:00' - TIMESTAMP '2050-05-05 13:10:10')/3600) as dhour; 

select date('2050-01-10') - date('2050-01-01') as dday; 

PostgreSQL时间差计算

时间加减

select current_timestamp,current_timestamp + interval '1 year',
current_timestamp + interval '1 month',
current_timestamp + interval '1 day',
current_timestamp + interval '1 hour',
current_timestamp + interval '1 min',
current_timestamp + interval '1 sec';

select now() + interval '1 year 1 month 1 day 1 hour 1 min 1 sec' as r;

select now() + (2 || ' day')::interval as r;

-- date类型:2050-01-17
select date '2050-01-10' + integer '7' as r;
-- date类型:2050-01-10
select date '2050-01-10' + interval '1 hour' as r;

select date '2050-01-01' + time '06:00' as r;

-- timestamp类型:2050-01-01 06:00:00.000
select timestamp '2050-01-01' + time '06:00' as r;


-- 返回interval类型:1 day -01:00:00
select interval '1 day' - interval '1 hour' as r1,
interval '1 hour' * double precision '3.5' as r2,
interval '1 hour' / double precision '1.5' as r3,
timestamp '2050-01-01 23:00' - interval '23 hours' as r4,
date '2050-10-01' - interval '1 hour' as r5;

PostgreSQL时间之间计算

日期时间格式化字符串

常用格式化字符

模式描述
YYYY4位年
MM月份号(01-12)
DD一个月里的日子(01-31)
HH24一天的小时数(00-23)
MI分钟(00-59)
SS秒(00-59)
MS毫秒(000-999)

其他格式化字符

模式描述
HH一天的小时数(01-12)
HH12一天的小时数(01-12)
US微秒(000000-999999)
AM正午标识(大写)
Y,YYY带逗号的年(4和更多位)
YYY年的后三位
YY年的后两位
Y年的最后一位
MONTH全长大写月份名(空白填充为9字符)
Month全长混合大小写月份名(空白填充为9字符)
month全长小写月份名(空白填充为9字符)
MON大写缩写月份名(3字符)
Mon缩写混合大小写月份名(3字符)
mon小写缩写月份名(3字符)
DAY全长大写日期名(空白填充为9字符)
Day全长混合大小写日期名(空白填充为9字符)
day全长小写日期名(空白填充为9字符)
DY缩写大写日期名(3字符)
Dy缩写混合大小写日期名(3字符)
dy缩写小写日期名(3字符)
DDD一年里的日子(001-366)
D一周里的日子(1-7;周日是1)
W一个月里的周数(1-5)(第一周从该月第一天开始)
WW一年里的周数(1-53)(第一周从该年的第一天开始)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2244634.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【MATLAB源码-第218期】基于matlab的北方苍鹰优化算法(NGO)无人机三维路径规划,输出做短路径图和适应度曲线.

操作环境: MATLAB 2022a 1、算法描述 北方苍鹰优化算法(Northern Goshawk Optimization,简称NGO)是一种新兴的智能优化算法,灵感来源于北方苍鹰的捕猎行为。北方苍鹰是一种敏捷且高效的猛禽,广泛分布于北…

Android Studio启动模拟器显示超时

问题报错: Timed out after 300seconds waiting for emulator to come online. 解决方案:升级Android Emulator 情况二:Error while waiting for device:AVD Pixel_4a_API_32 is already running. If that is not the case, delete the files at E:\An…

Stable Diffusion经典应用场景

🌺系列文章推荐🌺 扩散模型系列文章正在持续的更新,更新节奏如下,先更新SD模型讲解,再更新相关的微调方法文章,敬请期待!!!(本文及其之前的文章均已更新&…

linux 常用命令指南(存储分区、存储挂载、docker迁移)

前言:由于目前机器存储空间不够,所以‘斥巨资’加了一块2T的机械硬盘,下面是对linux扩容的一系列操作,包含了磁盘空间的创建、删除;存储挂载;docker迁移;anaconda3迁移等。 一、存储分区 1.1 …

AI时代,百度的三大主义

现实主义、长期主义、理想主义。 定焦One(dingjiaoone)原创 作者 | 苏琦 郑浩钧 编辑 | 魏佳 “人工智能很像是一次新的工业革命,这意味着它不会三五年就结束,也不会一两年就出现‘超级应用’,它更像是三五十年对于整…

服务器Docker OOM RSS高问题排查思路

优质博文:IT-BLOG-CN 防走弯路为防止走弯路,强烈建议先仔细阅读以下加粗内容: 如果你的应用是因为公司最近降成本调小实例物理内存才出现docker oom,而之前从来没有出现过,那么大概率是堆内存太大导致,这种…

Ubuntu Linux使用前准备动作_使用root登录图形化界面

Ubuntu默认是不允许使用 root 登录图形化界面的。这是出于安全考虑的设置。但如果有需要,可以通过以下步骤来实现使用 root 登录: 1、设置 root 密码 打开终端,使用当前的管理员账户登录系统。在终端中输入命令sudo passwd root&#xff0c…

core 不可变类型 线程安全 record

当一个类型的对象在创建时被指定状态后,就不会再变化的对象,我们称之为不可变类型。这种类型是线程安全的,不需要进行线程同步,非常适合并行计算的数据共享。它减少了更新对象会引起各种bug的风险,更为安全。 System.D…

Python-简单病毒程序合集(一)

前言:简单又有趣的Python恶搞代码,往往能给我们枯燥无味的生活带来一点乐趣,激发我们对编程的最原始的热爱。那么话不多说,我们直接开始今天的编程之路。 编程思路:本次我们将会用到os,paltform,threading,ctypes,sys,…

ForEach刷新UI机制

官网地址:ForEach 在ArkUI中,提供了ForEach循环语句,用来初始化一个列表数据,我们知道,当ForEach中的数组发生变化时,会引起UI的刷新,但是究竟如何变化,会引起UI怎样的刷新&#xf…

如何解决pdf.js跨域从url动态加载pdf文档

摘要 当我们想用PDF.js从URL加载文档时,将会因遇到跨域问题而中断,且是因为会触发了PDF.js和浏览器的双重CORS block,这篇文章将会介绍:①如何禁用pdf.js的跨域?②如何绕过浏览器的CORS加载URL文件?②如何使…

Three.js 相机控制器Controls

在 3D 场景中,摄像机的控制尤为重要,因为它决定了用户如何观察和与场景互动。Three.js 提供了多种相机控制器,最常用的有 OrbitControls、TrackballControls、FlyControls 和 FirstPersonControls。OrbitControls 适合用于查看和检查 3D 模型…

C++小白实习日记——Day 5 gitee怎么删文件,测试文件怎么写循环

昨晚一直内耗,一个程序写了三天写不出来,主要是耗时太多了,老板一直不满意。想在VScode上跑一下,昨晚一直报错。今天来公司重新搞了一下, 主要工作有: 1,读取当前时间用tscns 2,输…

【从零开始的LeetCode-算法】3301. 高度互不相同的最大塔高和

给你一个数组 maximumHeight ,其中 maximumHeight[i] 表示第 i 座塔可以达到的 最大 高度。 你的任务是给每一座塔分别设置一个高度,使得: 第 i 座塔的高度是一个正整数,且不超过 maximumHeight[i] 。所有塔的高度互不相同。 请…

利用uniapp开发鸿蒙:运行到鸿蒙模拟器—踩坑合集

从uniapp运行到鸿蒙模拟器上这一步,就有非常多的坑,一些常见的坑,官网都有介绍,就不再拿出来了,这里记录一下官网未记录的大坑 1.运行路径从hbuilderx启动鸿蒙模拟器 解决方法: Windows系统,官…

基于UDP和TCP实现回显服务器

目录 一. UDP 回显服务器 1. UDP Echo Server 2. UDP Echo Client 二. TCP 回显服务器 1. TCP Echo Server 2. TCP Echo Client 回显服务器 (Echo Server) 就是客户端发送什么样的请求, 服务器就返回什么样的响应, 没有任何的计算和处理逻辑. 一. UDP 回显服务器 1. UD…

游戏引擎学习第17天

视频参考:https://www.bilibili.com/video/BV1LPUpYJEXE/ 回顾上一天的内容 1. 整体目标: 处理键盘输入:将键盘输入的处理逻辑从平台特定的代码中分离出来,放入更独立的函数中以便管理。优化消息循环:确保消息循环能够有效处理 …

Ubuntu常见命令

关于export LD_LIBRARY_PATHcmake默认地址CMakelists.txt知识扩充/home:挂载新磁盘到 /home 子目录 关于export LD_LIBRARY_PATH 程序运行时默认的依赖库的位置包括lib, /usr/lib ,/usr/local/lib 通过命令export LD_LIBRARY_PATHdesired_path:$LD_LIBRARY_PATH追加…

Linux驱动开发快速入门——字符设备驱动(直接操作寄存器设备树版)

Linux驱动开发快速入门——字符设备驱动 前言 笔者使用开发板型号:正点原子的IMX6ULL-alpha开发板。ubuntu版本为:20.04。写此文也是以备忘为目的。 字符设备驱动 本小结将以直接操作寄存器的方式控制一个LED灯,可以通过read系统调用可以…

论文阅读 SeedEdit: Align Image Re-Generation to Image Editing

目录 摘要 1 INTRODUCTION 2 SEEDEDIT 2.1 T2I MODEL FOR EDITING DATA GENERATION 2.2 CAUSAL DIFFUSION MODEL WITH IMAGE INPUT 2.3 ITERATIVE ALIGNMENT 3 EXPERIMENTS 3.1 BENCHMARK AND METRICS 3.2 IMAGE EDITING COMPARISON 4 CONCLUSION 摘要 SeedEdit&…