具有多个$nin的Mongodb查询



我举了这个例子:

db.inventory.update( { tags: { $nin: [ "appliances", "school" ] } }, { $set: { sale: false } } )

形成mongodb.org网站。

每当我尝试多次使用$nin时,find_and_modify都会失败。我想要实现的目标:

db.inventory.update( { tags: { $nin: [ "appliances", "school" ]}, owners: {$nin : ["a","b"] }, { $set: { sale: false } } )

但我似乎不允许多次使用$nin。我知道$push不能那样使用,所以我只在多个字段上使用$push一次。但是,怎么能用它来换新币呢?

您可以多次使用$nin。这里有一个例子:

db.a.insert({odd : [1, 3, 5, 7, 9], even : [0, 2, 4, 6, 8]})
 db.a.find({
   odd : {$nin : [2, 6]},
   even : {$nin : [3, 7, 9]}
 }); // will return a document
 db.a.find({
   odd : {$nin : [2, 6, 1]},
   even : {$nin : [3, 7, 9]}
 }); // will NOT return a document because first odd has 1
 db.a.find({
   odd : {$nin : [2, 6, 1]},
   even : {$nin : [3, 7, 9]}
 }); // will NOT return a document because second even has 2

如果它能正确地找到它,那么它也可以修改

db.a.update(
  {odd : {$nin : [2, 6]}, even : {$nin : [3, 7, 9]}},
  {$set : {'correct' : 1}}
)
db.a.find().pretty()

这表明只有一个问题:你做错了什么

相关内容

  • 没有找到相关文章

最新更新