我有一张包含文章信息的表格。我有一个published_at
列timestamp without time zone
,想要计算每篇文章发布的时间,以天为单位。
因此,如果它在一周前发布,我应该回来7
。
知道如何去做吗?
我知道Postgres有NOW()
但是我可以减去然后再使用DAY()
吗?
谢谢!
答案 0 :(得分:3)
您可以从另一个日期中减去一个日期,结果将是两个日期之间的天数。如果其中一个是时间戳,只需将其转换为日期:
select current_date - published_at::date
from your_table;
如果你想获得那些年龄小于7天的人,你可以使用:
select current_date - published_at::date as age_in_days
from your_table
where published_at >= current_date - 7;
答案 1 :(得分:2)
你可以使用date_trunc,例如:
t=# select date_trunc('day',now() - '2016-01-01'::date);
date_trunc
------------
580 days
(1 row)
或数字结果,extract
t=# select extract('day' from date_trunc('day',now() - '2016-01-01'::date));
date_part
-----------
580
(1 row)