计算从午夜到现在的所有记录()

时间:2013-08-07 00:00:05

标签: sql ruby postgresql time pg

我正在尝试抓取从当天午夜创建的所有记录,直到按下按钮为止。

我曾经尝试过类似的东西,但它并没有真正解决问题。

SELECT COUNT(*) FROM ... AND a.lastAction > now() - interval '24 hour'"

我需要的是:

SELECT COUNT(*) FROM ... AND a.lastAction > midnight() AND a.lastAction < now()

有没有办法将"2013-08-06 00:00:01"之类的字符串转换为时间戳?

1 个答案:

答案 0 :(得分:5)

lastAction between current_date and now()   

select '2013-08-06 00:00:01'::timestamp;
      timestamp      
---------------------
 2013-08-06 00:00:01

Postgresql中的日期算术非常简单。可以加总或减去间隔的任何部分,如1.5小时

select '2013-08-06 00:00:01'::timestamp + 1.5 * interval '1 hour';
      ?column?       
---------------------
 2013-08-06 01:30:01