如何根据多个条件查找嵌入的Mongoid文档?

时间:2013-02-22 22:47:10

标签: ruby-on-rails mongodb mongoid

我有一个包含嵌入文档的Mongoid文档。我想搜索所有这些文档的顶级文档,其中存在具有多个条件的嵌入式文档。

TopDoc.where('inside.first_name' => 'Bob', 'inside.last_name' => 'Jones')

但在我看来,这将与Bob Wever和Paul Jones的TopDoc相匹配,这是错误的。

1 个答案:

答案 0 :(得分:7)

您需要使用$elemMatch。使用Mongoid,以下行应该可以解决问题

TopDoc.elem_match(inside: { first_name: 'Bob', last_name: 'Jones' })

相当于:

TopDoc.where(:inside.elem_match => { first_name: 'Bob', last_name: 'Jones'})