【转载】8天学通MongoDB——第八天 驱动实践
2012-10-18 10:03
288 查看
8天学通MongoDB——第八天 驱动实践
作为系列的最后一篇,得要说说C#驱动对mongodb的操作,目前驱动有两种:官方驱动和samus驱动,不过我个人还是喜欢后者,因为提供了丰富的linq操作,相当方便。
官方驱动:https://github.com/mongodb/mongo-csharp-driver/downloads。下载后,还提供了一个酷似msdn的帮助文档。
samus驱动:https://github.com/samus/mongodb-csharp/downloads。
下面就具体看看samus驱动,https://github.com/samus/mongodb-csharp/blob/master/examples/Simple/Main.cs上面提供了
一个简单的demo,大体上看看我们就知道怎么玩了。
一: 实践
1:我们建立一个Person实体,MongoAlias特性表示取别名,这里的ID值将会覆盖掉数据库自动生成的_id。
View Code
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Configuration; using System.Linq.Expressions; using MongoDB.Configuration; using MongoDB.Linq; using MongoDB.Attributes; namespace MongoDB.Test { 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:2222"; databaseName = "shopex"; 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 } #region 数据实体 /// <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; } } #endregion }
wow,趁着3天的休假,不断的努力终于把这个系列写完了,很感谢一直关注此系列的朋友。
相关文章推荐
- 【转载】8天学通MongoDB——第八天 驱动实践
- 8天学通MongoDB——第八天 驱动实践
- 8天学通MongoDB——第八天 驱动实践
- 8天学通MongoDB——第八天 驱动实践
- 8天学通MongoDB——第八天 驱动实践
- 8天学通MongoDB——第八天 驱动实践
- 8天学通MongoDB——第八天 驱动实践
- 8天学通MongoDB——第八天 驱动实践
- 8天学通MongoDB——第八天 驱动实践
- 8天学通MongoDB——第八天 驱动实践
- 8天学通MongoDB——第八天 驱动实践
- 8天学通MongoDB——第八天 驱动实践
- MongoDB_8天学通MongoDB——第八天 驱动实践
- 8天学通MongoDB——第八天 驱动实践
- 8天学通MongoDB——第八天 驱动实践
- 8天学通MongoDB——第八天 驱动实践
- 8天学通MongoDB——第八天 驱动实践
- 8天学通MongoDB——第八天 驱动实践
- 8天学通MongoDB——第八天 驱动实践
- 8天学通MongoDB——第八天 驱动实践