我正在从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.....]