sql >> Databasteknik >  >> NoSQL >> MongoDB

Rätt sätt att infoga många poster i Mongodb med Node.js

Om din MongoDB-server är 2.6 eller nyare skulle det vara bättre att använda skrivkommandon Bulk API som tillåter exekvering av bulkinsert-operationer som helt enkelt är abstraktioner ovanpå servern för att göra det enkelt att bygga bulk-operationer och därmed få prestandavinster med din uppdatering över stora samlingar.

Att skicka bulkinsert-operationerna i omgångar resulterar i mindre trafik till servern och utför därmed effektiva överföringar genom att inte skicka allt i individuella uttalanden, utan snarare delas upp i hanterbara bitar för serveråtagande. Det är också mindre tid att vänta på svaret i återuppringningen med detta tillvägagångssätt.

Dessa bulkoperationer kommer huvudsakligen i två smaker:

  • Beställda massoperationer . Dessa operationer utför alla operationer i ordning och fel vid det första skrivfelet.
  • Obeställda massoperationer . Dessa operationer utför alla operationer parallellt och aggregerar alla fel. Oordnade massoperationer garanterar inte utförandeordning.

Observera att för äldre servrar än 2.6 kommer API:et att nedkonvertera operationerna. Det är dock inte möjligt att nedkonvertera 100 %, så det kan finnas vissa kantfall där det inte kan rapportera rätt siffror korrekt.

I ditt fall kan du implementera Bulk API-insättningsoperationen i batcher om 1000 så här:

För MongoDB 3.2+ med bulkWrite

var MongoClient = require('mongodb').MongoClient;
var url = 'mongodb://localhost:27017/test';
var entries = [ ... ] // a huge array containing the entry objects

var createNewEntries = function(db, entries, callback) {

    // Get the collection and bulk api artefacts
    var collection = db.collection('entries'),          
        bulkUpdateOps = [];    

    entries.forEach(function(doc) {
        bulkUpdateOps.push({ "insertOne": { "document": doc } });

        if (bulkUpdateOps.length === 1000) {
            collection.bulkWrite(bulkUpdateOps).then(function(r) {
                // do something with result
            });
            bulkUpdateOps = [];
        }
    })

    if (bulkUpdateOps.length > 0) {
        collection.bulkWrite(bulkUpdateOps).then(function(r) {
            // do something with result
        });
    }
};

För MongoDB <3.2

var MongoClient = require('mongodb').MongoClient;
var url = 'mongodb://localhost:27017/test';
var entries = [ ... ] // a huge array containing the entry objects

var createNewEntries = function(db, entries, callback) {

    // Get the collection and bulk api artefacts
    var collection = db.collection('entries'),          
        bulk = collection.initializeOrderedBulkOp(), // Initialize the Ordered Batch
        counter = 0;    

    // Execute the forEach method, triggers for each entry in the array
    entries.forEach(function(obj) {         

        bulk.insert(obj);           
        counter++;

        if (counter % 1000 == 0 ) {
            // Execute the operation
            bulk.execute(function(err, result) {  
                // re-initialise batch operation           
                bulk = collection.initializeOrderedBulkOp();
                callback();
            });
        }
    });             

    if (counter % 1000 != 0 ){
        bulk.execute(function(err, result) {
            // do something with result 
            callback();             
        }); 
    } 
};

Anropa createNewEntries() funktion.

MongoClient.connect(url, function(err, db) {
    createNewEntries(db, entries, function() {
        db.close();
    });
});


  1. Modellera en NoSQL-forumapplikation med C# / ASP.net MVC

  2. PII-maskering i MongoDB och andra NoSQL-DB:er via...

  3. Meteor-sidan uppdateras med knappklick

  4. django admin filter och mongodb:Fångade DatabaseError under rendering:Denna fråga stöds inte av databasen