PostgreSQL日期和时间相关函数

示例:

--- 提取7天前的日期
SELECT (current_date - interval '7 day')::date as start_date

-- 明天的日期
SELECT (current_date + interval '1 day')::date as end_date

-- 当年的第一天
SELECT DATE_TRUNC('YEAR', CURRENT_DATE)::date
-- 2023-01-01

-- 当月的第一天
SELECT DATE_TRUNC('MONTH', CURRENT_DATE)::date
SELECT DATE_TRUNC('MONTH', current_timestamp)::date
-- 2023-12-01

-- 当年的最后一天
SELECT (DATE_TRUNC('YEAR', CURRENT_DATE+ INTERVAL '1 year') - interval '1 day')::date
-- 2023-12-31

-- 提取当前时间小时
select EXTRACT(HOUR FROM CURRENT_TIME)

时间类型

  • timestamp:时间戳。格式为1997-01-01 00:00:00,January 8 04:05:06 1999 PST

  • date:日期。格式为1997-01-01,19970101,1/1/1997,Jan-1-1997等

  • time:时间。12:00:00,120000,12:00,8:00 AM,8:00 PM等格式

  • interval:时间间隔。格式为: 1 year 2 months 3 days 4 hours 5 minutes 6 seconds

获取当前时间

  • now():获取当前完整时间
  • current_timestamp:当前事务开始时的时间戳,同 now() 函数等效
  • current_date:获取当前日期
  • current_time:获取当前时间
  • localtime:当前时间
  • localtimestamp:当前事务开始时的时间戳
-- 获取当前完整时间
select now(), current_timestamp, localtimestamp, clock_timestamp()
-- 2023-12-28 09:42:01.188 +0800, 2023-12-28 09:42:01.188 +0800, 2023-12-28 09:42:01.188, 2023-12-28 09:42:01.188 +0800

-- 获取当前日期或时间
select current_date, current_time, localtime;
-- 2023-12-28, 09:43:47 +0800, 09:43:47

时间加减

select now() + interval '2 years';
select now() + interval '2 year'; 
select now() + interval '2 y';
select now() + interval '2 Y';
select now() + interval '2Y';

-- 同理可得月周日时分秒: months, weeks, days, hours, minutes, seconds
SELECT
	now( ) + INTERVAL '2 years',--两年后
	now( ) + INTERVAL '1 month',--一个月后
	now( ) - INTERVAL '3 week',--三周前
	now( ) + '10 min';--十分钟后

格式转换

-- 时间转字符串
select to_char(now(), 'YYYY-MM-DD HH-MI:SS')
-- 2023-12-28 09-56:23

-- 字符串转日期
select to_date('05 Dec 2000', 'DD Mon YYYY')
-- 2000-12-05

-- 字符串转时间
select to_timestamp('05 Dec 2000', 'DD Mon YYYY')
-- 2000-12-05 00:00:00.000 +0800

-- Unix时间戳转时间
select to_timestamp(1703728867)
-- 2023-12-28 10:01:07.000 +0800

日期和时间字符串转换常用格式:

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)(第一周从该年的第一天开始)

相关函数

-- 时间间隔
select age('2023-11-11', '2023-11-1')
-- 10 days

-- 时间截取
select now(), date_part('hour', now()), date_part('min', now()), date_part('sec', now())
-- 2023-12-28 10:13:14.046 +0800, 10, 13, 14.046271

-- 截断至指定精度
select timestamp '2023-12-13 10:15:26', date_trunc('year', timestamp '2023-12-13 10:15:26'), date_trunc('month', timestamp '2023-12-13 10:15:26'), date_trunc('day', timestamp '2023-12-13 10:15:26'), date_trunc('hour', timestamp '2023-12-13 10:15:26')
-- 2023-12-13 10:15:26.000, 2023-01-01 00:00:00.000, 2023-12-01 00:00:00.000, 2023-12-13 00:00:00.000, 2023-12-13 10:00:00.000

-- 提取时间的年,月,日,时,分,秒
SELECT EXTRACT(YEAR FROM now()), EXTRACT(MONTH FROM now()), EXTRACT(DAY FROM now()), EXTRACT(HOUR FROM now()), EXTRACT(MIN FROM now()), EXTRACT(SEC FROM now())

PostgreSQL的日期/时间函数 https://blog.csdn.net/Super_King_/article/details/121521421
PostgreSQL函数——时间函数 https://blog.csdn.net/qq_33459369/article/details/119417288

  • 8
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
PostgreSQL 提供了许多用于处理日期时间函数。其中一些函数根据当前事务的开始时刻返回结果,比如CURRENT_DATE、CURRENT_TIME、CURRENT_TIMESTAMP、LOCALTIME、LOCALTIMESTAMP、now()和transaction_timestamp()。 此外,PostgreSQL 还提供了一些用于格式化数据类型的函数,包括日期/时间、整数、浮点数和小数。例如,to_char函数可以将时间戳、时间间隔、整数、双精度数和小数转换为指定格式的字符串。to_date函数可以将字符串转换为日期,to_timestamp函数可以将字符串转换为时间戳,to_number函数可以将字符串转换为数字。这些函数都有一个公共的调用习惯:第一个参数是待格式化或转换的值,而第二个参数是用于定义输出或输入格式的模板。 举例来说,to_char函数可以将时间戳转换为字符串,如to_char(current_timestamp, 'HH12:MI:SS')。to_char函数还可以将时间间隔、整数、浮点数和小数转换为字符串。to_date函数可以将字符串转换为日期,如to_date('05 Dec 2000', 'DD Mon YYYY')。to_timestamp函数可以将字符串转换为时间戳,如to_timestamp('05 Dec 2000', 'DD Mon YYYY')。to_number函数可以将字符串转换为数字,如to_number('12,454.8-', '99G999D9S')。 总之,PostgreSQL 提供了丰富的日期时间函数以及数据类型格式化函数,可以满足各种处理日期时间的需求。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [PostgreSQL日期/时间函数(兼容oracle)](https://download.csdn.net/download/weixin_38499553/13684201)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* *3* [PostgreSQL时间格式及相关函数实践](https://blog.csdn.net/dimawei2225/article/details/102041771)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值