欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 财经 > 创投人物 > pg_sql关于时间的函数

pg_sql关于时间的函数

2025/2/22 3:03:57 来源:https://blog.csdn.net/brhhh_sehe/article/details/145643887  浏览:    关键词:pg_sql关于时间的函数

1、时间戳和日期之间的相互转换

时间戳转日期(时间戳为数值类型,若为字符型需进行转换)

# 保留到秒:2025-10-02 04:46:40 (字符型转换数值型)
select to_timestamp('1759351600'::bigint)# 保留到日:2025-10-02
select date(to_timestamp(1759351600))# 自定义格式:2025/10/02
to_char(to_timestamp(1759351600),'YYYY/mm/dd')

2、interval

作用:实现时间日期的加减

格式:日期 +/- interval ‘加减值’

# 前一天
select current_date - interval '1 day'# 后一周
select current_date + interval '1 week'# 前一月
select current_date - interval '1 month'# 后一年
select current_date + interval '1 year'

3、date_trunc

作用:获取日期对应参数的起始

格式:date_trunc((‘参数’,日期))

# 获取年第一天
select date_trunc('year',now())# 获取年最后一天(获取下一年的第一天后减一天)
select date_trunc('year',now() + interval '1 year') - interval '1 day'# 获取季第一天
select date_trunc('quarter',now())# 获取季最后一天
select date_trunc('quarter',now() + interval '3 month') - interval '1 day'# 获取月第一天
select date_trunc('month',now())# 获取月最后一天
select date_trunc('month',now() + interval '1 month') - interval '1 day'# 获取周第一天
select date_trunc('week',now())# 获取周最后一天
select date_trunc('week',now() + interval '1 week') - interval '1 day'

计算类:

剩余时间

# 周
select date_trunc('week',now() + interval '1 week') - now()# 月
select date_trunc('month',now() + interval '1 month') - now()# 季
select date_trunc('quarter',now() + interval '3 month') - now()# 年
select date_trunc('year',now() + interval '1 year') - now()

剩余天数

# 周
select date_trunc('week',current_date + interval '1 week') - interval '1 day' - current_date # 月
select date_trunc('month',current_date  + interval '1 month') - interval '1 day' - current_date # 季
select date_trunc('quarter',current_date  + interval '3 month') - interval '1 day' - current_date # 年
select date_trunc('year',current_date  + interval '1 year') - interval '1 day' - current_date 

4、date_part

作用:获取日期对应的参数是当前年的第几(周、月、季)

格式:date_part(‘参数’,日期)

# 获取当前时间是第几天
select date_part('day',now())# 获取当前时间是第几周
select date_part('week',now())# 获取当前时间是第几月
select date_part('month',now())# 获取当前时间是第几季
select date_part('quarter',now())

5.extract

作用:提取时间中某些内容(可以实现和date_part类似功能)

格式:extract(提取值from时间)

# 天
select extract(day from current_date)# 月
select extract(month from current_date)# 年
select extract(year from current_date)# 周
select extract(week from current_date)# 季
select extract(quarter from current_date)

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

热搜词