【问题标题】:Multiple db queries with RABL and Mongoid/Moped使用 RABL 和 Mongoid/Moped 进行多个数据库查询
【发布时间】:2013-01-30 23:06:15
【问题描述】:

我有一个使用 rabl 和 mongoid 3.1.0 的简单应用程序,执行以下操作:

# index
@products = current_shop.products

rabl 代码如下所示:

# index.json.rabl
collection @products
extends 'api/products/show'

# show.json.rabl
object @product
attributes :id

当我点击它时,日志显示与@products 相关的 4 个请求:

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)

重复的查询看起来很奇怪,有人知道为什么会这样吗?它不调用子对象,只是与我所看到的有所不同的集合查询。

【问题讨论】:

  • 试试@products = current_shop.products.to_a

标签: mongoid rabl moped


【解决方案1】:

很多人遇到同样的问题。很可能是因为 rabl 配置问题。正如上面 Aymeric 所推荐的,只需执行以下操作: @products = current_shop.products.to_a

【讨论】:

    猜你喜欢
    • 2013-03-04
    • 1970-01-01
    • 2012-07-17
    • 1970-01-01
    • 2011-08-13
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多