MongoDB
 sql >> база данни >  >> NoSQL >> MongoDB

MongoDB актуализира множество поддокументи с или заявка

Получихте тази грешка

поради съвпадението на втората ви заявка с множество поддокументи . В момента не е възможно да използвате позиционния оператор за актуализиране на всички елементи в масив с помощта на позиционен оператор.

за да разрешите проблема си, можете да следвате този процес

  1. Намерете документ с помощта на _id и за намиране на поддокумент с помощта на $elemMatch и след това

  2. актуализирайте всеки поддокумент и запазете документа отново

можете да опитате така:

db.deduplications.find(  
{ $or: [ {
         "_id": ObjectId("583fc558668bde730a460e11") , 
        "DeviceVersionPairs":{
            $elemMatch:{ "DeviceId": ObjectId("5822d0606bfdcd6ec407d9b9") , 
            "CloudFolderId": ObjectId("5823110e6bfdd46ec4357582") ,
            "DeviceVersionPairs.CloudFileId": ObjectId("582311168cd396223499942a") ,
            "DeviceVersionPairs.VersionId": ObjectId("582311168cd396223499942b") }}
    } ,   
    { 
        "_id": ObjectId("583fc558668bde730a460e11") , 
        "DeviceVersionPairs":{
            $elemMatch:{ "DeviceId": ObjectId("56dfe1356caaea14a819f1e4") , 
            "CloudFolderId": ObjectId("583fb4bc6e7f341874f13bfc") , 
            "CloudFileId": ObjectId("583fb539e015b8a53fb71872") , 
            "VersionId": ObjectId("583fb4ca6e7f331874213584") }}
    } ] 
}).forEach(function (doc) {
    doc.DeviceVersionPairs.forEach(function (device) {
      device.status = 'passive';
    });
    db.deduplications.save(doc);
 });


  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. mongodump Неуспешно:лоша опция:може да изхвърли само една колекция в stdout

  2. Mongo:намерете поддокумент без нотация с точка

  3. синтаксис за свързване на документи в mongodb

  4. Конфигуриране на сигнали за метрики на MongoDB

  5. Произволна извадка от MongoDB, връщаща силно изкривени резултати