Ruby on rails 3 - 从MongoDB返回包含数据的JSON



我正在从MongoDB获取数据,如下所示:

@bs = coll2.find("date" => {"$gte" => initial_date, "$lte" => Time.now.utc})

它工作正常,但是当我渲染@bs时,它发送的是空的。

  render :json => @bs

如果我做一个 @bs.each 并将每个渲染为 json,它可以工作,但是,我想发送整个@bs。

谢谢

默认情况下,#find返回一个 Mongo::Cursor 对象,而不是实际结果。您需要首先将cursur(@bs)转换为包含结果的数组,然后将其呈现为json。

render :json => @bs.to_a.to_json

请注意,由于它是游标,因此一旦返回结果或开始迭代结果,则to_a调用将不会返回所有结果。需要调用 rewind! 来重置结果集:

> @bs.to_a
# => [{"_id" => BSON::ObjectID.....]
> @bs.to_a
# => []
> @bs.rewind!
# => true
> @bs.to_a
# => [{"_id" => BSON::ObjectID.....]

相关内容

  • 没有找到相关文章

最新更新