在三个集合中使用聚合查找后,我得到以下结果。
[{
_id : "henten",
location: "some place",
devices: [
{"d_id": 'd0001',
"z_id": 'z2001'},
{"d_id": 'd0002',
"z_id": 'z2002'}
],
store: [
{"z_name" : 'vera',
"z_id" : 'z2001'},
{"z_name" : 'ghora',
"z_id" : 'z2002'}
]
}]
如果 devices.z_id 与 store.z_id 匹配,我需要将“d_id”的值作为数组推送到“store”的字典中,并添加到名为“DID”的新字段中。
我尝试了以下方法:
{
$addFields: {
"store.DID" :
{$filter: {
input: "$devices.d_id",
as: 'did',
cond: {$eq: ['$devices.z_id', '$store.z_id']}
}}
}}
我还尝试了 $redact 和 $arrayElemAt,它们给我的错误结果如下:
[{
_id : "henten",
location: "some place",
devices: [
{"d_id": 'd0001',
"z_id": 'z2001'},
{"d_id": 'd0002',
"z_id": 'z2002'}
],
store: [
{"z_name" : 'vera',
"z_id" : 'z2001',
"DID" : ['d0001', 'd0002']},
{"z_name" : 'ghora',
"z_id" : 'z2002',
"DID" : ['d0001', 'd0002']}
]
}]
而正确答案应该是:
[{
_id : "henten",
location: "some place",
devices: [
{"d_id": 'd0001',
"z_id": 'z2001'},
{"d_id": 'd0002',
"z_id": 'z2002'}
],
store: [
{"z_name" : 'vera',
"z_id" : 'z2001',
"DID" : ['d0001']},
{"z_name" : 'ghora',
"z_id" : 'z2002',
"DID" : ['d0002']}
]
}]
我应该如何处理这个问题?一个 z_id 可以有两个不同的 d_id,因此应该在 DID 数组中包含这两个 d_id。
最佳答案
db.col.aggregate([
{
$addFields: {
store: {
$map: {
input: "$store",
as: "s",
in: {
z_name: "$$s.z_name",
z_id: "$$s.z_id",
DID: {
$map: {
input: {
$filter: {
input: "$devices",
as: "d",
cond: { $eq: [ "$$d.z_id", "$$s.z_id" ] }
}
},
as: "filtered",
in: "$$filtered.d_id"
}
}
}
}
}
}
}
])
关于mongodb aggregation : if value of two fields match, 将相应字典的另一个字段的值添加到新字段,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55684494/
当我使用Bundler时,是否需要在我的Gemfile中将其列为依赖项?毕竟,我的代码中有些地方需要它。例如,当我进行Bundler设置时:require"bundler/setup" 最佳答案 没有。您可以尝试,但首先您必须用鞋带将自己抬离地面。 关于ruby-我需要将Bundler本身添加到Gemfile中吗?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/4758609/
使用带有Rails插件的vim,您可以创建一个迁移文件,然后一次性打开该文件吗?textmate也可以这样吗? 最佳答案 你可以使用rails.vim然后做类似的事情::Rgeneratemigratonadd_foo_to_bar插件将打开迁移生成的文件,这正是您想要的。我不能代表textmate。 关于ruby-使用VimRails,您可以创建一个新的迁移文件并一次性打开它吗?,我们在StackOverflow上找到一个类似的问题: https://sta
我需要从一个View访问多个模型。以前,我的links_controller仅用于提供以不同方式排序的链接资源。现在我想包括一个部分(我假设)显示按分数排序的顶级用户(@users=User.all.sort_by(&:score))我知道我可以将此代码插入每个链接操作并从View访问它,但这似乎不是“ruby方式”,我将需要在不久的将来访问更多模型。这可能会变得很脏,是否有针对这种情况的任何技术?注意事项:我认为我的应用程序正朝着单一格式和动态页面内容的方向发展,本质上是一个典型的网络应用程序。我知道before_filter但考虑到我希望应用程序进入的方向,这似乎很麻烦。最终从任何
我想要做的是有2个不同的Controller,client和test_client。客户端Controller已经构建,我想创建一个test_clientController,我可以使用它来玩弄客户端的UI并根据需要进行调整。我主要是想绕过我在客户端中内置的验证及其对加载数据的管理Controller的依赖。所以我希望test_clientController加载示例数据集,然后呈现客户端Controller的索引View,以便我可以调整客户端UI。就是这样。我在test_clients索引方法中试过这个:classTestClientdefindexrender:template=>
我有一个ModularSinatra应用程序,我正在尝试将Bootstrap添加到应用程序中。get'/bootstrap/application.css'doless:"bootstrap/bootstrap"end我在views/bootstrap中有所有less文件,包括bootstrap.less。我收到这个错误:Less::ParseErrorat/bootstrap/application.css'reset.less'wasn'tfound.Bootstrap.less的第一行是://CSSReset@import"reset.less";我尝试了所有不同的路径格式,但它
我有一个表单,其中有很多字段取自数组(而不是模型或对象)。我如何验证这些字段的存在?solve_problem_pathdo|f|%>... 最佳答案 创建一个简单的类来包装请求参数并使用ActiveModel::Validations。#definedsomewhere,atthesimplest:require'ostruct'classSolvetrue#youcouldevencheckthesolutionwithavalidatorvalidatedoerrors.add(:base,"WRONG!!!")unlesss
我想向我的Controller传递一个参数,它是一个简单的复选框,但我不知道如何在模型的form_for中引入它,这是我的观点:{:id=>'go_finance'}do|f|%>Transferirde:para:Entrada:"input",:placeholder=>"Quantofoiganho?"%>Saída:"output",:placeholder=>"Quantofoigasto?"%>Nota:我想做一个额外的复选框,但我该怎么做,模型中没有一个对象,而是一个要检查的对象,以便在Controller中创建一个ifelse,如果没有检查,请帮助我,非常感谢,谢谢
如果您尝试在Ruby中的nil对象上调用方法,则会出现NoMethodError异常并显示消息:"undefinedmethod‘...’fornil:NilClass"然而,有一个tryRails中的方法,如果它被发送到一个nil对象,它只返回nil:require'rubygems'require'active_support/all'nil.try(:nonexisting_method)#noNoMethodErrorexceptionanymore那么try如何在内部工作以防止该异常? 最佳答案 像Ruby中的所有其他对象
关闭。这个问题需要detailsorclarity.它目前不接受答案。想改进这个问题吗?通过editingthispost添加细节并澄清问题.关闭8年前。Improvethisquestion为什么SecureRandom.uuid创建一个唯一的字符串?SecureRandom.uuid#=>"35cb4e30-54e1-49f9-b5ce-4134799eb2c0"SecureRandom.uuid方法创建的字符串从不重复?
我知道我可以指定某些字段来使用pluck查询数据库。ids=Item.where('due_at但是我想知道,是否有一种方法可以指定我想避免从数据库查询的某些字段。某种反拔?posts=Post.where(published:true).do_not_lookup(:enormous_field) 最佳答案 Model#attribute_names应该返回列/属性数组。您可以排除其中一些并传递给pluck或select方法。像这样:posts=Post.where(published:true).select(Post.attr