微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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

如何解决使用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
    

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。