微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

PostgreSQL的时间/日期函数使用

PostgreSQL的时间/日期函数使用

Postgresql的常用时间函数使用整理如下:

一、获取系统时间函

1.1 获取当前完整时间

select Now();

david=# select Now();
              Now              
-------------------------------
 2013-0412 15:39:40.399711+08
(1 row)

david=# 

current_timestamp 同 Now() 函数等效。

select current_timestamp; Now 40:22.398709

1.2 获取当前日期

select current_date;

select current_date; date ---------- 12

1.3 获取当前时间

select current_time;

current_time; timetz ------------------ 43:31.101726=#

二、时间的计算

47:13.244721

2.1 两年后

select Now() + interval '2 years'; ?column? 201549:03.1688512 year; ?12.3787272 y; ?? ---------------------------- 25.469862 Y28.4108532Y31.122831

2.2 一个月后

1 month; ?0551:22.24373one month; ERROR: invalid input Syntax for type interval: "one month" LINE 1: ; ^ david

2.3 三周前

- interval 3 week0322 16:00:04.203735

2.4 十分钟后

+ 10 min; ?12:47.445744

说明:

interval 可以不写,其值可以是:

Abbreviation Meaning
Y Years
M Months (in the date part)
W Weeks
D Days
H Hours
M Minutes (in the time part)
S Seconds



2.5 计算两个时间差

使用age(timestamp,timestamp)

select age(Now(),timestamp 1989-02-05); age -------------------------------------- 24 years 2 mons 7 days 17:05:49.119848
select age(2007-09-15); age ---------------------- 5 years 6 mons 27 days (三、时间字段的截取

在开发过程中,经常要取日期的年,月,日,小时等值,Postgresql 提供一个非常便利的EXTRACT函数

EXTRACT(field FROM source)

field 表示取的时间对象,source 表示取的日期来源,类型为 timestamp、time 或 interval。

3.1 取年份

select extract(year from Now()); date_part --------- 2013

3.2 取月份

month Now()); date_part --------- 4day from 2013-04-13); date_part --------- 13SELECT EXTRACT(DAY FROM INTERVAL 40 days 1 minute40

3.3 查看今天是一年中的第几天

select extract(doy --------- 102

3.4 查看现在距1970-01-01 00:00:00 UTC 的秒数

select extract(epoch Now()); date_part ---------------- 1365755907.94474

3.5把epoch 值转换回时间戳

SELECT TIMESTAMP WITH TIME ZONE epoch' + 1369755555 * INTERVAL 1 second; ?? 28 23:15

以上是基本的PG时间/日期函数使用,可满足一般的开发运维应用。

详细用法请参考:

Postgresql官方说明:http://www.postgresql.org/docs/9.2/static/functions-datetime.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐