2

我有这两个模型:

class Presentation
  include Mongoid::Document
  embeds_many :presentation_rows
end

class PresentationRow
  include Mongoid::Document
  embedded_in :presentation
end

在我的presentation_rows_controller.rb 我有这些代码行:

def show
  @presentation = Presentation.find(params[:id])
  @presentation_rows = @presentation.presentation_rows
end

def destroy
  ...
  ...
end

在我的 presentation_rows/show.html.haml 我有这些代码行:

- @presentation_rows.each do |presentation_row|
  = link_to "Delete", presentation_row, method: :delete

我在销毁控制器操作中尝试了许多方法,但它们都指向一个明显的事实,即我试图在不通过其父级的情况下销毁嵌入式文档。但是现在我在我的视图文件中通过它的 id 拥有了presentation_row,我不应该被允许销毁它似乎很愚蠢。

带有空销毁操作的错误消息,仅供参考:

Started DELETE "/en/presentation_rows/516af0a983c336708300000f" for 127.0.0.1 at 2013-04-14 20:08:47 +0200
Processing by PresentationRowsController#destroy as HTML
  Parameters: {"authenticity_token"=>"KHGG2dsTseCl88okOKW9JAlHb+VaK2lKIxb0ptAIC7A=", "locale"=>"en", "id"=>"516af0a983c336708300000f"}
  MOPED: 127.0.0.1:27017 QUERY        database=shop_import_development collection=users selector={"$query"=>{"_id"=>"511a813a83c336a0ea000001"}, "$orderby"=>{:_id=>1}} flags=[:slave_ok] limit=-1 skip=0 fields=nil (0.3152ms)
  MOPED: 127.0.0.1:27017 QUERY        database=shop_import_development collection=presentations selector={"_id"=>"516af0a983c336708300000f"} flags=[:slave_ok] limit=0 skip=0 fields=nil (0.2129ms)
Completed 500 Internal Server Error in 2ms

Mongoid::Errors::DocumentNotFound (
Problem:
  Document(s) not found for class Presentation with id(s) 516af0a983c336708300000f.
Summary:
  When calling Presentation.find with an id or array of ids, each parameter must match a document in the database or this error will be raised. The search was for the id(s): 516af0a983c336708300000f ... (1 total) and the following ids were not found: 516af0a983c336708300000f.
Resolution:
  Search for an id that is in the database or set the Mongoid.raise_not_found_error configuration option to false, which will cause a nil to be returned instead of raising this error when searching for a single id, or only the matched documents when searching for multiples.):
  app/controllers/presentation_rows_controller.rb:16:in `correct_user?'


  Rendered /Users/christoffer/.rvm/gems/ruby-1.9.3-p385/gems/actionpack-3.2.8/lib/action_dispatch/middleware/templates/rescues/_trace.erb (1.0ms)
  Rendered /Users/christoffer/.rvm/gems/ruby-1.9.3-p385/gems/actionpack-3.2.8/lib/action_dispatch/middleware/templates/rescues/_request_and_response.erb (0.8ms)
  Rendered /Users/christoffer/.rvm/gems/ruby-1.9.3-p385/gems/actionpack-3.2.8/lib/action_dispatch/middleware/templates/rescues/diagnostics.erb within rescues/layout (9.2ms

我应该在销毁动作中添加什么?

4

1 回答 1

7

这是 mongoid 的一个限制。Quoth 一个贡献者“必须始终通过父级访问嵌入式文档。” https://github.com/mongoid/mongoid/issues/348

请注意,这不是 mongodb 的限制。PresentationRow从其 id获取对象的解决方法是...

pres = Presentation.where('presentation_rows._id' => Moped::BSON::ObjectId(params[:id])).first
row = pres.presentation_rows.detect { |pr| pr.id.to_s == params[:id] }
row.destroy

presentation_rows._id如果您有很多索引,请添加索引。

于 2013-04-16T05:32:45.090 回答