PostgreSQL中的日期/時間函數(shù)詳解
零、前言
公司里有一臺阿里云RDS數(shù)據(jù)庫用了PPAS(Postgres PlusTM Advanced Server),在處理日期/時間時遇到一些問題,花了點時間整理如下。
一、獲取當前時間
select now()select current_timestampselect localtimestampselect clock_timestamp()

有時候,我們不需要這么完整細致的時間,自然就有
select current_dateselect current_timeselect 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';
結(jié)果都是一樣的:

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。
三、格式化函數(shù)
3.1時間轉(zhuǎn)字符串
to_char(timestamp,text)

3.2字符串轉(zhuǎn)日期
to_date(text,text)

3.3字符串轉(zhuǎn)時間
to_timestamp(text,text)

3.4Unix時間戳轉(zhuǎn)時間
to_timestamp(unixtime)

關于時間格式的模式,丟表跑:
| 模式 | 描述 |
|---|---|
| HH | 一天的小時數(shù)(01-12) |
| HH12 | 一天的小時數(shù)(01-12) |
| HH24 | 一天的小時數(shù)(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 | 一個月里的周數(shù)(1-5)(第一周從該月第一天開始) |
| WW | 一年里的周數(shù)(1-53)(第一周從該年的第一天開始) |
四、一些重要函數(shù)
4.1時間間隔
age(timestamp, timestamp)

當然也可以只輸入一個參數(shù),計算current_date與入?yún)⒌臅r間間隔。

4.2時間截取
date_part(text, timestamp) extract(field from timestamp)

還可以截斷至指定精度
date_trunc(text, timestamp)

如圖所示,小時后的分和秒被置為0。
五、時間的轉(zhuǎn)換
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時間戳的轉(zhuǎn)換 SELECT TIMESTAMP 'epoch' + 1341174767 * INTERVAL '1 second'; --2012-07-01 20:32:47
六、收!
到此這篇關于PostgreSQL中日期/時間函數(shù)詳解的文章就介紹到這了,更多相關PostgreSQL日期/時間函數(shù)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
PostgreSQL?10分區(qū)表及性能測試報告小結(jié)
PostgreSQL的分區(qū)表跟先前版本一樣,也要先建立主表,然后再建立子表,使用繼承的特性,但不需要手工寫規(guī)則了,目前支持range、list分區(qū),10正式版本發(fā)布時不知會不會支持其它方法,感興趣的朋友跟隨小編一起看看吧2022-01-01
Cenots7 離線安裝部署PostgreSQL 的詳細過程
這篇文章主要介紹了Cenots7 離線安裝部署PostgreSQL 的詳細過程,本文通過圖文并茂的形式給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-10-10
postgreSQL使用pgAdmin備份服務器數(shù)據(jù)的方法
這篇文章主要介紹了postgreSQL使用pgAdmin備份服務器數(shù)據(jù)的方法,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-02-02
PostgreSQL數(shù)據(jù)庫時間類型相加減操作
PostgreSQL提供了許多函數(shù),這些函數(shù)返回與當前日期和時間相關的值,下面這篇文章主要給大家介紹了關于PostgreSQL數(shù)據(jù)庫時間類型相加減操作的相關資料,需要的朋友可以參考下2023-10-10
在PostgreSQL中實現(xiàn)跨數(shù)據(jù)庫的關聯(lián)查詢
在 PostgreSQL 中,通常情況下的關聯(lián)查詢是在同一個數(shù)據(jù)庫的不同表之間進行的,然而,在某些復雜的應用場景中,可能需要實現(xiàn)跨數(shù)據(jù)庫的關聯(lián)查詢,本文將詳細探討如何在 PostgreSQL 中實現(xiàn)這一需求,并通過示例代碼進行說明,需要的朋友可以參考下2024-08-08
docker安裝Postgresql數(shù)據(jù)庫及基本操作
PostgreSQL是一個強大的開源對象-關系型數(shù)據(jù)庫管理系統(tǒng),以其高可擴展性和標準化而著稱,這篇文章主要介紹了docker安裝Postgresql數(shù)據(jù)庫及基本操作的相關資料,需要的朋友可以參考下2025-03-03

