首页 > 代码库 > c#开发Mongo笔记第五篇

c#开发Mongo笔记第五篇

现在增删查改算是都完成了,但是查询算是有点不完美的,相信现在用juqeryeasyui这一类的插件的人应该也不少吧,这样的话前台展示需要JSON格式的数据,

好在mogno驱动提供toJson()的函数,但是却无法在前台显示,不知道是不是objectid导致的,下面是我通过firebug看到的请求数据。

{"total":"2","rows":[{ "_id" : ObjectId("545c395937d9dc8a18f0c51a"), "UserName" : "admin", "Password" : "81DC9BDB52D04DC20036DBD8313ED055", "CustomID" : CSUUID("21410650-4219-46eb-baac-3a207a570225") }, { "_id" : ObjectId("545c66438ef275179cd6b02b"), "UserName" : "tester", "Password" : "E10ADC3949BA59ABBE56E057F20F883E", "CustomID" : CSUUID("deb396b4-e90b-449a-86b2-957bc0fc7f06") }]}{"total":"2","rows":[{"_id":"545c395937d9dc8a18f0c51a","UserName":"admin","CustomID":"21410650-4219-46eb-baac-3a207a570225"},{"_id":"545c66438ef275179cd6b02b","UserName":"tester","CustomID":"deb396b4-e90b-449a-86b2-957bc0fc7f06"}]}

上边是toJson()函数生成的,不知道怎么能去掉objectid这样不和谐的东西,希望知道的大牛不吝赐教。

然后说话我的查询方法吧,我首先返回一个collection

  public static MongoCollection GetCollection()        {            MongoDatabase db = MongoHelper.GetConnection();            return db.GetCollection<User>("User");        }

然后先把这个collection转成List集合再进行分页和查询操作

 

   MongoCollection collection = DAL.DALUser.GetCollection();            var list=  collection.FindAllAs<User>();            List<User> users = list.ToList();            if (Request.QueryString["condition"] != null)            {                searchstr = Request.QueryString["condition"];                users = list.Where(u=>u.UserName.Contains(searchstr)).ToList();            }

本想这样直接变成json的

       // return Content("{\"total\":\""+list.Count()+"\",\"rows\":"+ users.Take(TakeNum).Skip(TakeNum*SkipNum).ToJson().ToString()+"}");

但是不可以,目前只好先自己拼json了。

然后说说更新吧,查询我也是先写了一个更新方法

   public static void Update(IMongoQuery query,IMongoUpdate  update)        {            MongoDatabase db = MongoHelper.GetConnection();            MongoCollection collection = db.GetCollection<User>("User");            collection.Update(query, update);        }

通过传参的方式进行修改,我觉得这样还是相对灵活的,然后调用方法如下

                    var query = Query.And(Query.EQ("_id", user._id));                    var update = Update.Set("Password", user.Password);                    DALUser.Update(query, update);

然后业务逻辑层去指定查询方法和具体需要修改的字段。

c#开发Mongo笔记第五篇