PostgreSQL中的日期/时间函数详解

 更新时间:2022年01月12日 12:46:11   作者:喜碧夫人听众  
这篇文章主要给大家介绍了关于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会默认为分钟的加减,针对月的加减建议写完整的month或months或者简写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。

五、时间的转换

select timestamp '2012-05-12 18:54:54';  --2012-05-12 18:54:54
select date '2012-05-12 18:54:54';       --2012-05-12
select time  '2012-05-12 18:54:54';      --18:54:54
select TIMESTAMP WITH TIME ZONE '2012-05-12 18:54:54'   
--2012-05-12 18:54:54+08

--与unix时间戳的转换
SELECT TIMESTAMP 'epoch' + 1341174767 * INTERVAL '1 second'; 
--2012-07-01 20:32:47

六、收!

到此这篇关于PostgreSQL中日期/时间函数详解的文章就介绍到这了,更多相关PostgreSQL日期/时间函数内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • PostgreSQL备份工具 pgBackRest使用详解

    PostgreSQL备份工具 pgBackRest使用详解

    这篇文章主要介绍了PostgreSQL备份工具 pgBackRest使用详解,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-02-02
  • PostgreSQL 10分区表及性能测试报告小结

    PostgreSQL 10分区表及性能测试报告小结

    PostgreSQL的分区表跟先前版本一样,也要先建立主表,然后再建立子表,使用继承的特性,但不需要手工写规则了,目前支持range、list分区,10正式版本发布时不知会不会支持其它方法,感兴趣的朋友跟随小编一起看看吧
    2022-01-01
  • postgresql高级应用之合并单元格的思路详解

    postgresql高级应用之合并单元格的思路详解

    这篇文章主要介绍了postgresql高级应用之合并单元格,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-05-05
  • PostgreSQL新手入门教程

    PostgreSQL新手入门教程

    本文介绍PostgreSQL的安装和基本用法,供初次使用者上手。以下内容基于Debian操作系统,其他操作系统实在没有精力兼顾,但是大部分内容应该普遍适用
    2014-06-06
  • Cenots7 离线安装部署PostgreSQL 的详细过程

    Cenots7 离线安装部署PostgreSQL 的详细过程

    这篇文章主要介绍了Cenots7 离线安装部署PostgreSQL 的详细过程,本文通过图文并茂的形式给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-10-10
  • Postgresql 查询表引用或被引用的外键操作

    Postgresql 查询表引用或被引用的外键操作

    这篇文章主要介绍了Postgresql 查询表引用或被引用的外键操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-02-02
  • postgreSQL使用pgAdmin备份服务器数据的方法

    postgreSQL使用pgAdmin备份服务器数据的方法

    这篇文章主要介绍了postgreSQL使用pgAdmin备份服务器数据的方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-02-02
  • PostgreSQL数据库时间类型相加减操作

    PostgreSQL数据库时间类型相加减操作

    PostgreSQL提供了许多函数,这些函数返回与当前日期和时间相关的值,下面这篇文章主要给大家介绍了关于PostgreSQL数据库时间类型相加减操作的相关资料,需要的朋友可以参考下
    2023-10-10
  • 在PostgreSQL中实现跨数据库的关联查询

    在PostgreSQL中实现跨数据库的关联查询

    在 PostgreSQL 中,通常情况下的关联查询是在同一个数据库的不同表之间进行的,然而,在某些复杂的应用场景中,可能需要实现跨数据库的关联查询,本文将详细探讨如何在 PostgreSQL 中实现这一需求,并通过示例代码进行说明,需要的朋友可以参考下
    2024-08-08
  • docker安装Postgresql数据库及基本操作

    docker安装Postgresql数据库及基本操作

    PostgreSQL是一个强大的开源对象-关系型数据库管理系统,以其高可扩展性和标准化而著称,这篇文章主要介绍了docker安装Postgresql数据库及基本操作的相关资料,需要的朋友可以参考下
    2025-03-03

最新评论