MongoDB
 sql >> Baza danych >  >> NoSQL >> MongoDB

Zaktualizuj dokument, używając wyniku połączonych pól

Musisz użyć .aggregate() metoda, która zapewnia dostęp do potoków agregacji.

W Twoim $project etap, który musisz użyć $concat operator do łączenia pola.

Następnie możesz użyć wyniku agregacji, aby zaktualizować swoją kolekcję za pomocą "bulk" operacje na rzecz wydajności

var bulk = db.events.initializeOrderedBulkOp(); 
var count = 0;
db.events.aggregate([
    { "$project": {
        "iso_start": { "$concat": [ "$date", " ", "$time" ] }, 
        "iso_end": { "$concat": [ "$date", " ", "$endtime" ] }    
    }}
]).forEach(function(doc) { 
    bulk.find({'_id': doc._id}).updateOne({
        "$set": {
            "iso_start": new Date(doc.iso_start),
            "iso_end": new Date(doc.iso_end)
        }
    }); 
    count++; 
    if(count % 200 === 0) { 
        // update per 200 operations and re-init
        bulk.execute();     
        bulk = db.events.initializeOrderedBulkOp(); 
    } 
})
// Clean up queues
if(count > 0) bulk.execute();

Po tej operacji Twoje dokumenty wyglądają tak:

{
        "_id" : "aaaaaaaaaaaa",
        "title" : "Hello, World!",
        "date" : "Thursday, November 12, 2015",
        "time" : "9:30 AM",
        "endtime" : "11:30 AM",
        "iso_start" : ISODate("2015-11-12T06:30:00Z"),
        "iso_end" : ISODate("2015-11-12T08:30:00Z")
}
{
        "_id" : "bbbbbbbbbbbb",
        "title" : "To B or not to B",
        "date" : "Thursday, November 12, 2015",
        "time" : "10:30 AM",
        "endtime" : "11:00 AM",
        "iso_start" : ISODate("2015-11-12T07:30:00Z"),
        "iso_end" : ISODate("2015-11-12T08:00:00Z")
}

To nie koniec historii, ponieważ "Bulk" API i powiązane z nim metody są przestarzałe w nadchodzącym wydaniu (wersja 3.2 ), dlatego od tej wersji będziemy musieli użyć db.collection.bulkWrite() metoda.

var operations = [];
db.events.aggregate([
    { "$project": {
        "iso_start": { "$concat": [ "$date", " ", "$time" ] }, 
        "iso_end": { "$concat": [ "$date", " ", "$endtime" ] }    
    }}
]).forEach(function(doc) {
    var operation = {
        updateOne: { 
            filter: { "_id": doc._id }, 
            update: { 
                "$set":  { 
                   "iso_start": new Date(doc.iso_start),
                   "iso_end": new Date(doc.iso_end)
                }
            }
        }
    }; 
    operations.push(operation); 
})
operations.push({ ordered: true, writeConcern: { w: "majority", wtimeout: 5000 } });
db.events.bulkWrite(operations)



  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. jak używać $lookup stage w java z wiosennym mongodbem?

  2. Spring Data - indeksowanie MongoDB DBRef

  3. Zmienne środowiskowe aplikacji Meteor

  4. Jak wyszukiwać w indeksie pełnotekstowym za pomocą php w mongodb

  5. Używanie @Resource injection dla Mongo db, wewnątrz Web Bundle wewnątrz OSGI, pod Liberty Profile