sql >> Database teknologi >  >> NoSQL >> MongoDB

Udfør mongodb shell script via C# driver

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

Dette er nyttigt, når du forsøger at ændre egenskabstyper, f.eks. som denne:

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");
}

Denne kode ændrer type someProperty som er et element i en samling af en samling:

some_items mongo collection:

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

}


  1. Opret et ISO-datoobjekt i javascript

  2. MongoDB begrænse lagerstørrelse?

  3. spring data mongodb id felt mapping

  4. Opdater indlejret objekt i array inde i array i MongoDB