4

我有一个嵌入了许多“SuggestedPerson”的模型“Person”。SuggestedPerson 还引用另一个人(被建议的人)。所以 Person 需要 embed_many 和 has_many SuggestedPerson。问题是 Mongo 返回错误:

失败/错误:Mongoid::Errors::MixedRelations:

   Problem:
     Referencing a(n) SuggestedPerson document from the Person document via a relational association is not allowed since the

SuggestedPerson 被嵌入。

代码:

class Person
  embeds_many :suggested_persons, :class_name => "SuggestedPerson", :inverse_of => :person
  has_many :suggested_to_persons, :class_name => "SuggestedPerson", :inverse_of => :to_person
end

class SuggestedPerson
  embedded_in :person, :class_name => "Person", :inverse_of => :suggested_persons 
  belongs_to :to_person, :class_name => "Person", :inverse_of => :suggested_to_persons
end

有没有解决的办法?

4

1 回答 1

0

由于 Mongoid 只能做其中之一,因此需要一种解决方法。这是一个(未经测试的)示例,希望能让您朝着正确的方向前进。

如果您需要嵌入的 SuggestedPerson 对象来引用另一个 Person 对象(除了父对象),您可能需要在 SuggestedPerson 嵌入对象上创建一个字段,例如:

field :person_being_suggested_id, type: String

该属性可以存储另一个 Person 对象的 ID。在您的 SuggestedPerson 表单上,假设我们在 SuggestedPerson 控制器 (@persons = Person.all) 中有一个包含所有 Persons 的实例变量,并且 Persons 有一个 name 属性,这样我们就可以使用这个不错的方法从下拉列表中进行选择帮手:

<%= f.collection_select(:person_being_suggested_id, @persons, :id, :name, {prompt: ""}) %>

在您的 SuggestedPerson 模型中,您可以使用以下方法:

def suggested_persons_name
  Person.find_by(id: self.person_being_suggested_id).name
end

这样,当您使用 Person 类的实例时,您可以调用如下内容:

@person.suggested_persons.each do |person|
  p person.suggested_persons_name
end

或者说您正在使用 SuggestedPerson 类的实例:

@suggested_person.suggested_persons_name

第一个示例将遍历 Person 对象中所有嵌入的 SuggestedPersons,在每个对象上调用方法Suggested_persons_name 并将返回所有名称的列表。第二个示例将仅返回为该特定嵌入文档建议的人的姓名。

于 2014-03-05T18:33:35.760 回答