網(wǎng)站首頁(yè) 編程語(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
相關(guān)推薦
- 2022-08-22 Python利用watchdog模塊監(jiān)控文件變化_python
- 2023-02-01 Bat腳本之在文件中查找多個(gè)字符串并保存到文件中_DOS/BAT
- 2022-10-24 C語(yǔ)言進(jìn)度條的實(shí)現(xiàn)原理詳解_C 語(yǔ)言
- 2022-09-07 Python和C語(yǔ)言利用棧分別實(shí)現(xiàn)進(jìn)制轉(zhuǎn)換_python
- 2022-08-07 Go?gRPC超時(shí)控制Deadlines用法詳解_Golang
- 2022-09-21 Python安裝和配置uWSGI的詳細(xì)過(guò)程_python
- 2022-10-23 Redis的過(guò)期鍵刪除策略原理說(shuō)明_Redis
- 2022-06-27 Golang編程并發(fā)工具庫(kù)MapReduce使用實(shí)踐_Golang
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細(xì)win安裝深度學(xué)習(xí)環(huán)境2025年最新版(
- Linux 中運(yùn)行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲(chǔ)小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運(yùn)算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認(rèn)證信息的處理
- Spring Security之認(rèn)證過(guò)濾器
- Spring Security概述快速入門(mén)
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯(cuò)誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實(shí)現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務(wù)發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡(jiǎn)單動(dòng)態(tài)字符串(SD
- arthas操作spring被代理目標(biāo)對(duì)象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊(duì)列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠(yuǎn)程分支