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);
然后业务逻辑层去指定查询方法和具体需要修改的字段。