Postgres:获取自日期以来的天数

时间:2017-08-03 14:51:47

标签: postgresql

我有一张包含文章信息的表格。我有一个published_attimestamp without time zone,想要计算每篇文章发布的时间,以天为单位。

因此,如果它在一周前发布,我应该回来7

知道如何去做吗?

我知道Postgres有NOW()但是我可以减去然后再使用DAY()吗?

谢谢!

2 个答案:

答案 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)