sql >> Databasteknik >  >> NoSQL >> MongoDB

Kör mongodb-skalskript via C#-drivrutinen

var mongoServer = MongoServer.Create("mongodb://<connectionstring>"); 
var database = mongoServer.GetDatabase("mydatabase"); 
string mycollectionCount database.Eval("function() { return db.mycollection.count(); }").ToString();

Detta är användbart när du försöker ändra egenskapstyper till exempel så här:

string updateScript = @"
function () { 
    db.some_items.find().forEach(function(documentItem) {
        documentItem.some_collection.forEach(function(collectionItem) {
            if (typeof collectionItem.SomeProperty === 'number' 
                && Math.floor(collectionItem.someProperty) === collectionItem.someProperty)
            {
                collectionItem.someProperty = '' + collectionItem.someProperty;
            }
        });
        db.modules_elementary.save(documentItem);
    });

    return true;
}";
var updateResult = MongoReadDatabase.Database.Eval(updateScript).ToString();
if (updateResult != "true")
{
    throw new ApplicationException("Update of something failed");
}

Denna kod ändrar typ av someProperty som är en del av en samling av en samling:

some_items mongo collection:

{
   some_collection: [{ someProperty: 12, ....}],
   ....

}


  1. mongoDB distinkt &var i samma fråga?

  2. Python + Memcached:Effektiv cachelagring i distribuerade applikationer

  3. Hur kommer magento på cache-nyckelnamn?

  4. json.loads och Redis i python 3.5