3

我有一个 ElasticSearch 模型(由轮胎坚持,没有 ActiveRecord)。如果我查询它,我会得到一些带有某些方面的结果(如预期的那样)。

The format is: 

class Mention
  include Tire::Model::Persistence
  index_name 'mentions'

  # basic display attributes
  property :created_at, :type => 'date'
end

查询返回结果很好。当我检查返回的日期时,我得到一个字符串。

1.9.2p320 :046 > a.results[0].created_at
 => "2012-12-26T02:55:50+01:00" 
1.9.2p320 :047 > a.results[0].created_at.class
 => String 
1.9.2p320 :048 > a.results[1].created_at
 => "2012-12-26T02:55:50+01:00" 
1.9.2p320 :049 > a.results[2].created_at
 => "2012-12-26T02:56:33+01:00" 
1.9.2p320 :050 > a.results[2].created_at.class
 => String 

我有一个返回 date_histogram 的简单方面,只是为了按天检索与查询匹配的结果量。格式如下:

  facet 'volumes' do 
    date :created_at
  end

不幸的是,这似乎返回了一个疯狂的 Unix 时间戳。

1.9.2p320 :069 > d = a.helper.facets["volumes"]["entries"][0]["time"].to_s
 => "1356307200000" 
1.9.2p320 :070 > d.class
 => String 
1.9.2p320 :071 > Date.strptime(d, "%s")
 => Sun, 31 Aug 44949 
1.9.2p320 :072 > 

我一定是做错了什么。我是吗?如果是这样,是什么?

4

1 回答 1

7

Tire 不操纵方面响应,因此它返回 Elasticsearch 返回的原始值。

对于facet,时间戳以自纪元以​​来的毫秒date_histogram数返回。另一方面,Ruby从 epoch 开始使用秒数

您可以做的最简单的事情是简单地除以 1000:

>> d = a.helper.facets["volumes"]["entries"][0]["time"].to_i
=> 1356307200000
>> Time.at(d/1000)
=> 2012-12-24 01:00:00 +0100

可以说,轮胎可以/应该在这里为您进行转换。

于 2012-12-31T14:21:18.700 回答