PostgreSQL的日期/時間函式
阿新 • • 發佈:2018-11-23
零、前言
公司裡有一臺阿里雲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
部分可以不寫,以此類推,月、日、小時、分鐘、秒的加減計算也同理。
Abbreviation | Meaning |
---|---|
Y | Years |
M | Months (in the date part) |
W | Weeks |
D | Days |
H | Hours |
M | Minutes (in the time part) |
S | Seconds |
值得一提的是單寫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。