我有一个简单的应用程序,它使用rabl和mongoid 3.1.0,并执行以下操作:
# index
@products = current_shop.productsrabl代码如下所示:
# index.json.rabl
collection @products
extends 'api/products/show'
# show.json.rabl
object @product
attributes :id当我点击它时,日志显示了4个与@products相关的请求:
MOPED: 127.0.0.1:27017 QUERY database=bamboo_development collection=products selector={"$query"=>{"shop_id"=>"511c7866fd896b1908000002"}, "$orderby"=>{:_id=>1}} flags=[:slave_ok] limit=-1 skip=0 batch_size=nil fields=nil (0.5682ms)
MOPED: 127.0.0.1:27017 QUERY database=bamboo_development collection=products selector={"$query"=>{"shop_id"=>"511c7866fd896b1908000002"}, "$orderby"=>{:_id=>1}} flags=[:slave_ok] limit=-1 skip=0 batch_size=nil fields=nil (1.1139ms)
MOPED: 127.0.0.1:27017 QUERY database=bamboo_development collection=products selector={"$query"=>{"shop_id"=>"511c7866fd896b1908000002"}, "$orderby"=>{:_id=>1}} flags=[:slave_ok] limit=0 skip=0 batch_size=nil fields=nil (0.4492ms)
MOPED: 127.0.0.1:27017 QUERY database=bamboo_development collection=products selector={"$query"=>{"shop_id"=>"511c7866fd896b1908000002"}, "$orderby"=>{:_id=>1}} flags=[:slave_ok] limit=0 skip=0 batch_size=nil fields=nil (0.4332ms)当我这样做的时候:
@products = current_shop.products.search(params[:query])
render text: @products.map(&:name).join(",")我只收到一个与@products相关的请求:
MOPED: 127.0.0.1:27017 QUERY database=bamboo_development collection=products selector={"shop_id"=>"511c7866fd896b1908000002"} flags=[:slave_ok] limit=0 skip=0 batch_size=nil fields=nil (0.4611ms)重复的查询看起来很奇怪,有人知道为什么会这样吗?它不调用子对象,只是在我看来有点不同的集合查询。
发布于 2013-03-04 18:12:34
很多人都有同样的问题。最有可能的原因是rabl配置问题。按照Aymeric上面的建议,只需这样做:@products = current_shop.products.to_a
https://stackoverflow.com/questions/14886817
复制相似问题