using System; using System.Collections.Generic; using System.Linq; using MongoDB.Driver; namespace Console1 { internal class Program { private static void Main(string[] args) { //BsonClassMap.RegisterClassMap(); RunCode(); } private static void RunCode() { var settings = new MongoServerSettings(); int portNumber=999; settings.Server = new MongoServerAddress("mongoServer.com", portNumber); settings.DefaultCredentials = new MongoCredentials("username", "password", false); MongoServer mongo = MongoServer.Create(settings); var dbSettings = new MongoDatabaseSettings(mongo, "databaseName"); MongoDatabase mongoDb = mongo.GetDatabase(dbSettings); //this lists the names of the collections foreach (string collectoinName in mongoDb.GetCollectionNames()) { Write(collectoinName); } AddCrimeTomongoDbAndReadBackTheList(mongoDb); Write("Press x to exit, or any other key to Loop!"); ConsoleKeyInfo key = Console.ReadKey(); if (key.KeyChar != 'x') RunCode(); } private static void AddCrimeTomongoDbAndReadBackTheList(MongoDatabase db) { var crime = new Crime { Id = Guid.NewGuid(), When = DateTime.Now, Where = "Down town", NatureOfCrime = "Purse snatching", WitnessNames = new List {"Larry", "Curly", "Moe"} }; db.GetCollection ("Crime").Save(crime); List crimes = db.GetCollection("Crime").FindAllAs ().ToList(); int i = 0; foreach (Crime c in crimes) { i++; Write(string.Format("item {2}: {1} (id {0})", c.Id, c.NatureOfCrime, i)); } } private static void Write(string str) { Console.WriteLine(str); } } //this is a sample class which will be saved into mongoDB public class Crime { public Guid Id { get; set; } public string NatureOfCrime { get; set; } public string Where { get; set; } public DateTime When { get; set; } public List WitnessNames { get; set; } } }
Monday, December 19, 2011
MongoDB Experiment
This example shows how to connect to a mogoDB database using the mongo-csharp-driver (git checkout). The code below demonstrates how to insert data into a collection, and retrieve a collection and deserialize the data.
Subscribe to:
Post Comments (Atom)
No comments:
Post a Comment