C#驱动对mongodb的操做,目前驱动有两种:官方驱动和samus驱动(官方驱动比较原生态,业务扩展比较灵活;samus第三方驱动提供了丰富的linq操做,至关方便) 。mysql
官方驱动下载地址:https://github.com/mongodb/mongo-csharp-driver/downloadsgit
samus驱动下载地址:https://github.com/samus/mongodb-csharp/downloadsgithub
1、samus驱动使用示例:sql
实体类:mongodb
/// <summary> /// 数据实体 /// </summary> public class Person { [MongoAlias("_id")] public string ID { get; set; } public string Name { get; set; } public int Age { get; set; } public DateTime CreateTime { get; set; } }
Mongo数据库操做类:数据库
public class MongodbHelper<T> where T : class { string connectionString = string.Empty; string databaseName = string.Empty; string collectionName = string.Empty; static MongodbHelper<T> mongodb; #region 初始化操做 /// <summary> /// 初始化操做 /// </summary> public MongodbHelper() { connectionString = "Server=127.0.0.1:27017"; databaseName = "test"; collectionName = "person"; } #endregion #region 实现linq查询的映射配置 /// <summary> /// 实现linq查询的映射配置 /// </summary> public MongoConfiguration configuration { get { var config = new MongoConfigurationBuilder(); config.Mapping(mapping => { mapping.DefaultProfile(profile => { profile.SubClassesAre(t => t.IsSubclassOf(typeof(T))); }); mapping.Map<T>(); mapping.Map<T>(); }); config.ConnectionString(connectionString); return config.BuildConfiguration(); } } #endregion #region 插入操做 /// <summary> /// 插入操做 /// </summary> /// <param name="person"></param> /// <returns></returns> public void Insert(T t) { using (Mongo mongo = new Mongo(configuration)) { try { mongo.Connect(); var db = mongo.GetDatabase(databaseName); var collection = db.GetCollection<T>(collectionName); collection.Insert(t, true); mongo.Disconnect(); } catch (Exception) { mongo.Disconnect(); throw; } } } #endregion #region 更新操做 /// <summary> /// 更新操做 /// </summary> /// <param name="person"></param> /// <returns></returns> public void Update(T t, Expression<Func<T, bool>> func) { using (Mongo mongo = new Mongo(configuration)) { try { mongo.Connect(); var db = mongo.GetDatabase(databaseName); var collection = db.GetCollection<T>(collectionName); collection.Update<T>(t, func, true); mongo.Disconnect(); } catch (Exception) { mongo.Disconnect(); throw; } } } #endregion #region 获取集合 /// <summary> ///获取集合 /// </summary> /// <param name="person"></param> /// <returns></returns> public List<T> List(int pageIndex, int pageSize, Expression<Func<T, bool>> func, out int pageCount) { pageCount = 0; using (Mongo mongo = new Mongo(configuration)) { try { mongo.Connect(); var db = mongo.GetDatabase(databaseName); var collection = db.GetCollection<T>(collectionName); pageCount = Convert.ToInt32(collection.Count()); var personList = collection.Linq().Where(func).Skip(pageSize * (pageIndex - 1)) .Take(pageSize).Select(i => i).ToList(); mongo.Disconnect(); return personList; } catch (Exception) { mongo.Disconnect(); throw; } } } #endregion #region 读取单条记录 /// <summary> ///读取单条记录 /// </summary> /// <param name="person"></param> /// <returns></returns> public T Single(Expression<Func<T, bool>> func) { using (Mongo mongo = new Mongo(configuration)) { try { mongo.Connect(); var db = mongo.GetDatabase(databaseName); var collection = db.GetCollection<T>(collectionName); var single = collection.Linq().FirstOrDefault(func); mongo.Disconnect(); return single; } catch (Exception) { mongo.Disconnect(); throw; } } } #endregion #region 删除操做 /// <summary> /// 删除操做 /// </summary> /// <param name="person"></param> /// <returns></returns> public void Delete(Expression<Func<T, bool>> func) { using (Mongo mongo = new Mongo(configuration)) { try { mongo.Connect(); var db = mongo.GetDatabase(databaseName); var collection = db.GetCollection<T>(collectionName); //这个地方要注意,必定要加上T参数,不然会看成object类型处理 //致使删除失败 collection.Remove<T>(func); mongo.Disconnect(); } catch (Exception) { mongo.Disconnect(); throw; } } } #endregion }
调用操做类:c#
class Program { static void Main(string[] args) { MongodbHelper<Person> helper = new MongodbHelper<Person>(); //插入操做 for (int i = 0; i < 1000; i++) { helper.Insert(new Person() { ID = Guid.NewGuid().ToString(), Name = "jack" + i, Age = i, CreateTime = DateTime.Now }); } Console.WriteLine("插入成功"); //修改操做 var single = helper.Single(i => i.Name == "jack0"); single.Name = "mary"; helper.Update(single, i => i.ID == single.ID); Console.WriteLine("修改为功"); //删除操做 helper.Delete(i => i.Name == "mary"); Console.WriteLine("删除成功"); //查询操做 int pagecount; //获取名字里面带9的人数 var list = helper.List(1, 20, i => i.Name.Contains("9"), out pagecount); Console.WriteLine("名字里面带9的人数:" + pagecount); Console.Read(); } }
2、官方驱动使用示例:服务器
数据库操做类:app
class Program { static void Main(string[] args) { //MongoDB服务器链接串 string connectionString = "mongodb://127.0.0.1"; MongoServer server = MongoServer.Create(connectionString); //链接到 mongodb_c_demo 数据库 MongoDatabase db = server.GetDatabase("test"); //获取集合 fruit MongoCollection collection = db.GetCollection("fruit"); //建立对象 fruit_1 BsonDocument fruit_1 = new BsonDocument { { "name", "apple" }, { "color", "red" } }; //建立对象 fruit_2 BsonDocument fruit_2 = new BsonDocument { { "name", "banana" }, { "color", "yellow" } }; //将对象 fruit_1 放到集合 fruit 中 collection.Insert(fruit_1); //将对象 fruit_2 放到集合 fruit 中 collection.Insert(fruit_2); //以上代码完成的就是向fruit表中插入2条数据,用mysql的语法解释即 //insert into mongodb_c_demo.fruit (name, color) //values ('apple', 'red'), ('banana', 'yellow'); Console.Read(); }