PostgreSQL的日期/时间函数

零、前言

公司里有一台阿里云RDS数据库用了PPAS(Postgres PlusTM Advanced Server),在处理日期/时间时遇到一些问题,花了点时间整理如下。

一、获取当前时间

select now()
select current_timestamp
select localtimestamp
select clock_timestamp()
这里写图片描述
有时候,我们不需要这么完整细致的时间,自然就有
select current_date
select current_time
select localtime
这里写图片描述

二、时间的加减

老实说,这是见过最奇怪的一套时间计算的方式了。

select now() + interval '2 years';
select now() + interval '2 year'; 
select now() + interval '2 y';
select now() + interval '2 Y';
select now() + interval '2Y';

结果都是一样的:
这里写图片描述
interval部分可以不写,以此类推,月、日、小时、分钟、秒的加减计算也同理。

AbbreviationMeaning
YYears
MMonths (in the date part)
WWeeks
DDays
HHours
MMinutes (in the time part)
SSeconds

值得一提的是单写M会默认为分钟的加减,针对月的加减建议写完整的monthmonths或者简写mon

三、格式化函数

3.1时间转字符串

to_char(timestamp,text)
这里写图片描述

3.2字符串转日期

to_date(text,text)
这里写图片描述

3.3字符串转时间

to_timestamp(text,text)
这里写图片描述

3.4Unix时间戳转时间

to_timestamp(unixtime)
这里写图片描述
关于时间格式的模式,丢表跑:

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

四、一些重要函数

4.1时间间隔

age(timestamp, timestamp)
这里写图片描述
当然也可以只输入一个参数,计算current_date与入参的时间间隔。
这里写图片描述

4.2时间截取

date_part(text, timestamp)
extract(field from timestamp)
这里写图片描述
还可以截断至指定精度
date_trunc(text, timestamp)
这里写图片描述
如图所示,小时后的分和秒被置为0。

五、收!

  • 7
    点赞
  • 75
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
PostgreSQL 提供了许多用于处理日期时间函数。其中一些函数根据当前事务的开始时刻返回结果,比如CURRENT_DATE、CURRENT_TIME、CURRENT_TIMESTAMP、LOCALTIME、LOCALTIMESTAMP、now()和transaction_timestamp()。 此外,PostgreSQL 还提供了一些用于格式化数据类型的函数,包括日期/时间、整数、浮点数和小数。例如,to_char函数可以将时间戳、时间间隔、整数、双精度数和小数转换为指定格式的字符串。to_date函数可以将字符串转换为日期,to_timestamp函数可以将字符串转换为时间戳,to_number函数可以将字符串转换为数字。这些函数都有一个公共的调用习惯:第一个参数是待格式化或转换的值,而第二个参数是用于定义输出或输入格式的模板。 举例来说,to_char函数可以将时间戳转换为字符串,如to_char(current_timestamp, 'HH12:MI:SS')。to_char函数还可以将时间间隔、整数、浮点数和小数转换为字符串。to_date函数可以将字符串转换为日期,如to_date('05 Dec 2000', 'DD Mon YYYY')。to_timestamp函数可以将字符串转换为时间戳,如to_timestamp('05 Dec 2000', 'DD Mon YYYY')。to_number函数可以将字符串转换为数字,如to_number('12,454.8-', '99G999D9S')。 总之,PostgreSQL 提供了丰富的日期时间函数以及数据类型格式化函数,可以满足各种处理日期时间的需求。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [PostgreSQL日期/时间函数(兼容oracle)](https://download.csdn.net/download/weixin_38499553/13684201)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* *3* [PostgreSQL时间格式及相关函数实践](https://blog.csdn.net/dimawei2225/article/details/102041771)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值