使用MongoMapper查询文档中的嵌入文档

问题描述

| 查询文档中嵌入文档的良好模式是什么?例如,我的用户文档有一个嵌入式警报文档。如果我想查看给定用户是否有名称警报,我可以通过两种方式做到这一点-在内存中
alert = current_user.alerts.select{|a| a.name == params[:name]}.first
或通过实际的文档界面la(请注意,我不是100%确信这在语义上是有效的,但您可以理解这一点):
User.where(\'alerts.name\' => params[:name],:id => current_user.id).first
一定有更好的方法,例如
current_user.alerts.where(:name => params[:name])
也许?或者,也许我不是在考虑这个问题,对吗?     

解决方法

不。我认为这是动机: 在MongoMapper中,数据库查询始终返回一个根对象。允许查询返回没有父文档的嵌入式文档将是一个突破,并使很多事情变得更加复杂(如果我在该嵌入式文档中调用.parent呢?),因此MongoMappers偏向于简单性而不会假装事物不是它们。嵌入式文档存储在MongoDB根文档中的数组中,因此MongoMapper为您提供了Ruby中的数组。 因此,您的两种实现方式是预期的实现方式。 如果您需要一些语法suger,则编写起来应该不会太困难。您可以扩展Array或编写插件来扩展MongoMapper的嵌入式文档代理。     ,我认为Mongoid支持此功能,请参见嵌入式文档手册中的“查找”。     ,您可以执行以下任一操作:
User.where(\'alerts.name\' => params[:name],:id => current_user.id).fields(:alerts).first.alerts.select{|u| u.name == params[:name]}
要么
User.where(\'alerts.name\' => params[:name],:id => current_user.id).fields(:alerts).alerts.select{|u| u.name == params[:name]}.first