PostgreSQL中的日期/时间函数详解(post提交json数据)干货分享

随心笔谈9个月前更新 admin
218 00
🌐 经济型:买域名、轻量云服务器、用途:游戏 网站等 《腾讯云》特点:特价机便宜 适合初学者用 点我优惠购买
🚀 拓展型:买域名、轻量云服务器、用途:游戏 网站等 《阿里云》特点:中档服务器便宜 域名备案事多 点我优惠购买
🛡️ 稳定型:买域名、轻量云服务器、用途:游戏 网站等 《西部数码》 特点:比上两家略贵但是稳定性超好事也少 点我优惠购买

文章摘要

这篇文章介绍了PostgreSQL中处理日期和时间的常见操作和函数,重点总结了以下内容: 1. **时间加减操作**:展示了如何在PostgreSQL中对时间进行加减操作,包括年、月、日、小时、分钟、秒等单位。需要注意的是,时间单位的格式化和使用规则,例如`YY`代表年,`MM`代表月,`WW`代表周。 2. **时间格式化函数**:详细介绍了如何使用`date_part`函数提取时间的特定部分(如年、月、日、小时等),以及如何截取时间到指定精度。此外,文章还展示了如何将时间格式化为字符串,并解释了不同格式化规则(如`HH`代表24小时制,`AM`代表正午标记等)。 3. **时间转换**:介绍了如何将时间转换为不同格式,并展示了如何使用时间戳进行计算,包括与Unix时间戳的转换。 4. **时间截取**:文章详细讲解了如何截取时间到指定精度,例如将时间设置为小时后的时间,使分钟和秒被置为0。 总结而言,文章通过具体的示例和详细的解释,帮助读者更好地理解和使用PostgreSQL中的日期和时间函数。文章末尾还提到了更多相关文章,供读者进一步学习。



目录零、前言一、获取当前时间二、时间的加减三、格式化函数3.1时间转字符串3.2字符串转日期3.3字符串转时间3.4Unix时间戳转时间四、一些重要函数4.1时间间隔4.2时间截取五、时间的转换六、收!

公司里有一台阿里云RDS数据库用了PPAS(Postgres PlusTM Advanced Server),在处理日期/时间时遇到一些问题,花了点时间整理如下。

有时候,我们不需要这么完整细致的时间,自然就有

老实说,这是见过最奇怪的一套时间计算的方式了。

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

结果都是一样的:

interval部分可以不写,以此类推,月、日、小时、分钟、秒的加减计算也同理。

AbbreviationMeaningYYearsMMonths (in the date part)WWeeksDDaysHHoursMMinutes (in the time part)SSeconds

值得一提的是单写M会默认为分钟的加减,针对月的加减建议写完整的month或months或者简写mon。

关于时间格式的模式,丢表跑:

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

当然也可以只输入一个参数,计算current_date与入参的时间间隔。

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

还可以截断至指定精度

如图所示,小时后的分和秒被置为0。

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时间戳的转换
SELECT TIMESTAMP ‘epoch’ + 1341174767 * INTERVAL ‘1 second’;
–2012-07-01 20:32:47

到此这篇关于PostgreSQL中日期/时间函数详解的文章就介绍到这了,更多相关PostgreSQL日期/时间函数内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:PostgreSQL 如何获取当前日期时间及注意事项postgresql中时间转换和加减操作PostgreSQL中常用的时间日期脚本使用教程postgresql 计算时间差的秒数、天数实例postgresql 实现查询某时间区间的所有日期案例PostgreSQL时间处理的一些常用方式总结

© 版权声明

相关文章