日本免费高清视频-国产福利视频导航-黄色在线播放国产-天天操天天操天天操天天操|www.shdianci.com

學(xué)無(wú)先后,達(dá)者為師

網(wǎng)站首頁(yè) 編程語(yǔ)言 正文

PostgreSQL中的日期/時(shí)間函數(shù)詳解_PostgreSQL

作者:喜碧夫人聽(tīng)眾 ? 更新時(shí)間: 2022-03-27 編程語(yǔ)言

零、前言

公司里有一臺(tái)阿里云RDS數(shù)據(jù)庫(kù)用了PPAS(Postgres PlusTM Advanced Server),在處理日期/時(shí)間時(shí)遇到一些問(wèn)題,花了點(diǎn)時(shí)間整理如下。

一、獲取當(dāng)前時(shí)間

  • select now()
  • select current_timestamp
  • select localtimestamp
  • select clock_timestamp()

有時(shí)候,我們不需要這么完整細(xì)致的時(shí)間,自然就有

  • select current_date
  • select current_time
  • select localtime

二、時(shí)間的加減

老實(shí)說(shuō),這是見(jiàn)過(guò)最奇怪的一套時(shí)間計(jì)算的方式了。

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部分可以不寫(xiě),以此類推,月、日、小時(shí)、分鐘、秒的加減計(jì)算也同理。

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

值得一提的是單寫(xiě)M會(huì)默認(rèn)為分鐘的加減,針對(duì)月的加減建議寫(xiě)完整的month或months或者簡(jiǎn)寫(xiě)mon。

三、格式化函數(shù)

3.1時(shí)間轉(zhuǎn)字符串

to_char(timestamp,text)

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

to_date(text,text)

3.3字符串轉(zhuǎn)時(shí)間

to_timestamp(text,text)

3.4Unix時(shí)間戳轉(zhuǎn)時(shí)間

to_timestamp(unixtime)

關(guān)于時(shí)間格式的模式,丟表跑:

模式 描述
HH 一天的小時(shí)數(shù)(01-12)
HH12 一天的小時(shí)數(shù)(01-12)
HH24 一天的小時(shí)數(shù)(00-23)
MI 分鐘(00-59)
SS 秒(00-59)
MS 毫秒(000-999)
US 微秒(000000-999999)
AM 正午標(biāo)識(shí)(大寫(xiě))
Y,YYY 帶逗號(hào)的年(4和更多位)
YYYY 年(4和更多位)
YYY 年的后三位
YY 年的后兩位
Y 年的最后一位
MONTH 全長(zhǎng)大寫(xiě)月份名(空白填充為9字符)
Month 全長(zhǎng)混合大小寫(xiě)月份名(空白填充為9字符)
month 全長(zhǎng)小寫(xiě)月份名(空白填充為9字符)
MON 大寫(xiě)縮寫(xiě)月份名(3字符)
Mon 縮寫(xiě)混合大小寫(xiě)月份名(3字符)
mon 小寫(xiě)縮寫(xiě)月份名(3字符)
MM 月份號(hào)(01-12)
DAY 全長(zhǎng)大寫(xiě)日期名(空白填充為9字符)
Day 全長(zhǎng)混合大小寫(xiě)日期名(空白填充為9字符)
day 全長(zhǎng)小寫(xiě)日期名(空白填充為9字符)
DY 縮寫(xiě)大寫(xiě)日期名(3字符)
Dy 縮寫(xiě)混合大小寫(xiě)日期名(3字符)
dy 縮寫(xiě)小寫(xiě)日期名(3字符)
DDD 一年里的日子(001-366)
DD 一個(gè)月里的日子(01-31)
D 一周里的日子(1-7;周日是1)
W 一個(gè)月里的周數(shù)(1-5)(第一周從該月第一天開(kāi)始)
WW 一年里的周數(shù)(1-53)(第一周從該年的第一天開(kāi)始)

四、一些重要函數(shù)

4.1時(shí)間間隔

age(timestamp, timestamp)

當(dāng)然也可以只輸入一個(gè)參數(shù),計(jì)算current_date與入?yún)⒌臅r(shí)間間隔。

4.2時(shí)間截取

date_part(text, timestamp)
extract(field from timestamp)

還可以截?cái)嘀林付ň?/p>

date_trunc(text, timestamp)

如圖所示,小時(shí)后的分和秒被置為0。

五、時(shí)間的轉(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時(shí)間戳的轉(zhuǎn)換
SELECT TIMESTAMP 'epoch' + 1341174767 * INTERVAL '1 second'; 
--2012-07-01 20:32:47

六、收!

原文鏈接:https://blog.csdn.net/zhchs2012/article/details/79655939

欄目分類
最近更新