这篇文章主要介绍了postgresql 中的时间处理小技巧(推荐),本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下。
时间格式处理
按照给定格式返回:to_char(timestamp,format)
data:image/s3,"s3://crabby-images/6ea0a/6ea0a4a7304a3d13b2b3ffdb4aee37bcc0d5f713" alt=""
返回相差的天数:(date(time1) - current_date)
data:image/s3,"s3://crabby-images/9ebc9/9ebc96ea97484a8766d417a60e2ee429c305dfd5" alt=""
返回时间戳对应的的日期[yyyy-MM-dd]:date(timestamp)
data:image/s3,"s3://crabby-images/d467a/d467a39bf615962b81b18f8ef3005a22d978b2f8" alt=""
计算结果取两位小数(方便条件筛选):round((ABS(a-b)::numeric / a), 2) * 100 < 10
data:image/s3,"s3://crabby-images/0bfc1/0bfc15911c3eb75d59a53889813bad88559dc937" alt=""
时间运算
加减运算
'-' :前x天/月/年
'+' :后x天/月/年
current_timestamp - interval 'x day/month/year...' 返回时间戳
data:image/s3,"s3://crabby-images/a700e/a700eba23156d85b6c5be2b4e337c0013bcd6f70" alt=""
date_part('day', current_timestamp - time1) 两个时间相差的天数
data:image/s3,"s3://crabby-images/7210b/7210b7cd38c0f5c1b4959826e8c1469b46012fba" alt=""
返回时间间隔的秒数
两个timestamp 直接相减返回的是 interval类型,而不是毫秒数
extract(epoch from (time1- time2)) * 1000
data:image/s3,"s3://crabby-images/565de/565de1fed3ff52cd000b5a8a6a4463c2f23a4a4e" alt=""
如果在sql 中使用long类型的 timestamp,需要包裹 to_timestamp() 函数
data:image/s3,"s3://crabby-images/4c709/4c70959ec9f97f27bd251cd9a2238e73a1b8a1b8" alt=""
文章来源:脚本之家
来源地址:https://www.jb51.net/article/208544.htm
免责声明:本平台仅供信息发布交流之途,请谨慎判断信息真伪。如遇虚假诈骗信息,请立即举报
举报