C#驱动对mongodb的操作,目前驱动有两种:官方驱动和samus驱动(官方驱动比较原生态,业务扩展比较灵活;samus第三方驱动提供了丰富的linq操作,相当方便) 。
官方驱动下载地址:https://github.com/mongodb/mongo-csharp-driver/downloads
samus驱动下载地址:https://github.com/samus/mongodb-csharp/downloads
一、samus驱动使用示例:
实体类:
/// <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 }
调用操作类:
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(); } }
二、官方驱动使用示例:
数据库操作类:
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(); }