我有以下数据
{
"_id" : ObjectId("5cdcb640e6d43d2c91e432aa"),
"userID" : "quqrgfbf43adadonadb",
"taggedProducts" : [
{
"isChecked" : true,
"_id" : ObjectId("5cdcb640e6d43d2c91e432ab"),
"catalogSKU" : "MYLOAD 10",
"createdBy" : "string",
"modifiedBy" : "string",
"remarks" : "string",
"createdAt" : ISODate("2019-05-16T01:00:48.852Z"),
"updatedAt" : ISODate("2019-05-16T01:00:48.852Z")
},
{
"isChecked" : false,
"_id" : ObjectId("5cdcb675e6d43d2c91e432ac"),
"catalogSKU" : "MYLOAD 11",
"createdBy" : "string",
"modifiedBy" : "string",
"remarks" : "string",
"updatedAt" : ISODate("2019-05-16T01:01:41.450Z"),
"createdAt" : ISODate("2019-05-16T01:01:41.450Z")
},
{
"isChecked" : true,
"_id" : ObjectId("5cdcd76b61d09c0cdd6fafdd"),
"catalogSKU" : "MYLOAD 12",
"createdBy" : "string",
"modifiedBy" : "string",
"remarks" : "string",
"updatedAt" : ISODate("2019-05-16T03:22:19.525Z"),
"createdAt" : ISODate("2019-05-16T03:22:19.525Z")
}
],
"__v" : 0
}
目标:需要使用用户 ID 找到文档,然后返回所有 "taggedProducts" 和 isChecked: true
我尝试了很多关于此的帖子,但没有代码首先使用 .find 。建议是使用 .aggregate
我也试过使用 $elemMatch 但它只返回符合条件的第一个子文档。
谁能建议怎么做?
最佳答案
您不能使用 $elemMatch (projection)在这种情况下,因为它只返回 first 匹配元素。因此你需要 $filter作为聚合的一部分:
db.collection.aggregate([
{
$match: { userID: "quqrgfbf43adadonadb" }
},
{
$addFields: {
taggedProducts: {
$filter: {
input: "$taggedProducts",
cond: {
$eq: [ "$$this.isChecked", true ]
}
}
}
}
}
])
关于mongodb - Mongoose 找到然后返回带有条件的子文档,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56163770/
为什么4.1%2返回0.0999999999999996?但是4.2%2==0.2。 最佳答案 参见此处:WhatEveryProgrammerShouldKnowAboutFloating-PointArithmetic实数是无限的。计算机使用的位数有限(今天是32位、64位)。因此计算机进行的浮点运算不能代表所有的实数。0.1是这些数字之一。请注意,这不是与Ruby相关的问题,而是与所有编程语言相关的问题,因为它来自计算机表示实数的方式。 关于ruby-为什么4.1%2使用Ruby返
我有一个用户工厂。我希望默认情况下确认用户。但是鉴于unconfirmed特征,我不希望它们被确认。虽然我有一个基于实现细节而不是抽象的工作实现,但我想知道如何正确地做到这一点。factory:userdoafter(:create)do|user,evaluator|#unwantedimplementationdetailshereunlessFactoryGirl.factories[:user].defined_traits.map(&:name).include?(:unconfirmed)user.confirm!endendtrait:unconfirmeddoenden
我有一个包含多个键的散列和一个字符串,该字符串不包含散列中的任何键或包含一个键。h={"k1"=>"v1","k2"=>"v2","k3"=>"v3"}s="thisisanexamplestringthatmightoccurwithakeysomewhereinthestringk1(withspecialcharacterslike(^&*$#@!^&&*))"检查s是否包含h中的任何键的最佳方法是什么,如果包含,则返回它包含的键的值?例如,对于上面的h和s的例子,输出应该是v1。编辑:只有字符串是用户定义的。哈希将始终相同。 最佳答案
我有这样的哈希trial_hash={"key1"=>1000,"key2"=>34,"key3"=>500,"key4"=>500,"key5"=>500,"key6"=>500}我按值降序排列:my_hash=trial_hash.sort_by{|k,v|v}.reverse我现在是这样理解的:[["key1",1000],["key4",500],["key5",500],["key6",500],["key3",500],["key2",34]]但我希望当值相同时按键的升序排序。我该怎么做?例如:上面的散列将以这种方式排序:[["key1",1000],["key3",500
我有一些代码在几个不同的位置之一运行:作为具有调试输出的命令行工具,作为不接受任何输出的更大程序的一部分,以及在Rails环境中。有时我需要根据代码的位置对代码进行细微的更改,我意识到以下样式似乎可行:print"Testingnestedfunctionsdefined\n"CLI=trueifCLIdeftest_printprint"CommandLineVersion\n"endelsedeftest_printprint"ReleaseVersion\n"endendtest_print()这导致:TestingnestedfunctionsdefinedCommandLin
我有一个只接受一个参数的方法:defmy_method(number)end如果使用number调用方法,我该如何引发错误??通常,我如何定义方法参数的条件?比如我想在调用的时候报错:my_method(1) 最佳答案 您可以添加guard在函数的开头,如果参数无效则引发异常。例如:defmy_method(number)failArgumentError,"Inputshouldbegreaterthanorequalto2"ifnumbereputse.messageend#=>Inputshouldbegreaterthano
所以我开始关注ruby,很多东西看起来不错,但我对隐式return语句很反感。我理解默认情况下让所有内容返回self或nil但不是语句的最后一个值。对我来说,它看起来非常脆弱(尤其是)如果你正在使用一个不打算返回某些东西的方法(尤其是一个改变状态/破坏性方法的函数!),其他人可能最终依赖于一个返回对方法的目的并不重要,并且有很大的改变机会。隐式返回有什么意义?有没有办法让事情变得更简单?总是有返回以防止隐含返回被认为是好的做法吗?我是不是太担心这个了?附言当人们想要从方法中返回特定的东西时,他们是否经常使用隐式返回,这不是让你组中的其他人更容易破坏彼此的代码吗?当然,记录一切并给出
为什么以下不同?Time.now.end_of_day==Time.now.end_of_day-0.days#falseTime.now.end_of_day.to_s==Time.now.end_of_day-0.days.to_s#true 最佳答案 因为纳秒数不同:ruby-1.9.2-p180:014>(Time.now.end_of_day-0.days).nsec=>999999000ruby-1.9.2-p180:015>Time.now.end_of_day.nsec=>999999998
我正在学习http://ruby.railstutorial.org/chapters/static-pages上的RubyonRails教程并遇到以下错误StaticPagesHomepageshouldhavethecontent'SampleApp'Failure/Error:page.shouldhave_content('SampleApp')Capybara::ElementNotFound:Unabletofindxpath"/html"#(eval):2:in`text'#./spec/requests/static_pages_spec.rb:7:in`(root)'
在Ruby1.9.3(可能还有更早的版本,不确定)中,我试图弄清楚为什么Ruby的String#split方法会给我某些结果。我得到的结果似乎与我的预期相反。这是一个例子:"abcabc".split("b")#=>["a","ca","c"]"abcabc".split("a")#=>["","bc","bc"]"abcabc".split("c")#=>["ab","ab"]在这里,第一个示例返回的正是我所期望的。但在第二个示例中,我很困惑为什么#split返回零长度字符串作为返回数组的第一个值。这是什么原因呢?这是我所期望的:"abcabc".split("a")#=>["bc"