6

我正在使用以下带有 PG gem 的 ruby​​ 代码来返回 Postgres“没有时区的时间戳”格式的时间戳。我希望它返回值(-1 小时),而不是返回当前值。

def get_latest_timestamp(id)
  conn1 = PGconn.open(:dbname => 'testdb')
  res = conn1.exec("SELECT MAX(time_of_search) FROM listings WHERE id=#{id}")
  res.values[0][0]
end
4

1 回答 1

13

在 Postgres 中,您可以在时间戳中添加或减去间隔以生成另一个时间戳,如此所述。

所以在这种情况下,假设time_of_search是一个时间戳,你可以做

"SELECT MAX(time_of_search) - INTERVAL '1 hour' FROM listings WHERE id=#{id}"
于 2013-11-13T03:06:52.627 回答