mongodb为2.6版本,
.net是4.0,
c#接口时1.7。
运行环境为windows8 with visual studio2010
注意事项:在mongodb中使用地理位置存储信息且动用到范围查询的请先将其地理信息以数组的形式建立数据集(c#代码:double[] location{double latitude=*.*f,double longitude=*.*f})否则无法建立2d地理位置索引,然后在monggodb的collection(关系型数据库中的’表‘)中将此地理位置建立2d索引。网上有人表示建立此索引必须用户亲自操作数据库,不能使用.net中的collection.createIndex()或其他建立索引的接口。另外,很多人在c#中收集信息的类成员使用get{}set{}方法,在这里请务必小心大小写,代码的第40行中已注明。在做数据查询时写BsonDocument或query时一定要注意大小写因为mongodb区分大小写
操作实例:
1)连接数据库(nearby)
2)打开对应的collection
3)collection.createIndex()//这个是命令行或终端的方式(伪代码,详情请查询mongodb官方文档)
注:图形界面的话可以推荐两个软件:
--1)mongo vue (mongovue是Windows操作系统,给你一个优雅的、高度可用的GUI界面与MongoDB MongoDB桌面应用的创新。现在有一个不太担心管理您的网络规模数据。http://www.mongovue.com/ )
--2)umongo(UMongo (前身是 JMongoBrowser) 是一个图形化界面的工具,用来浏览和管理 MongoDB 集群,支持 Linux, Windows 和 Mac OSX.)
注:命令行或终端可以根据链接中的文档进行操作:http://docs.mongodb.org/manual/reference/method/
c#接口的官方文档:http://api.mongodb.org/csharp/current/html/R_Project_CSharpDriverDocs.htm
注:c#接口下载地址:http://www.nuget.org/packages/mongocsharpdriver/
或者在visual studio2012以上的版本使用nuget命令下载到项目中:Install-Package mongocsharpdriver
-----------------------------------------------------
1 public class MongoNearby 2 { 3 private static object objLock = new object(); 4 private static MongoDatabase mongo ; 5 6 private static MongoDatabase Instance 7 { 8 get 9 { 10 if (mongo == null) 11 { 12 lock (objLock)//防止多线程构造 13 { 14 string connctionString = "mongodb://192.168.1.x:27017"; 15 MongoClient client = new MongoClient(connctionString); 16 MongoServer server = client.GetServer(); 17 mongo = server.GetDatabase("nearby");//数据库 18 } 19 } 20 return mongo; 21 } 22 } 23 24 /// <summary> 25 /// 保存记录 26 /// </summary> 27 /// <param name="info"></param> 28 /// <returns></returns> 29 public static bool SaveNearby(NearInfo info) 30 { 31 if (info == null) 32 return false; 33 try 34 {//因为在mongodb中主键式objectId,所以在更新数据的话有两种方式:1)查出唯一键对应的主键值然后取出该行在更新,2)删除原有的数据再插入。注意:删除时要注意删除的数据是否符合业务需求(因为这种方式不以主键来删除行纪录) 35 MongoCollection collection = Instance.GetCollection<NearInfo>("userinfo"); 36 QueryDocument query = new QueryDocument(); 37 query.Add("userid", info.userid); 38 collection.Remove(query); 39 40 WriteConcernResult result = collection.Insert(info); 41 CLog.WriteLog("write: "+info.ToJson());//在插入操作时有必要输出log以备后用或使用mongodb的日志存储 42 return result.Ok; 43 } 44 catch(Exception ex) 45 { 46 CLog.WriteLog(ex.Message+info.ToJson()); 47 return false;//在这里应避免使用return,因为这里是数据访问及处理层,业务层调用时可能也使用try{}catch{}结构,所以建议使用throw,因为代码时测使用,所以当时没注意到 48 } 49 } 50 51 /// <summary> 52 /// 附近用户 53 /// </summary> 54 /// <param name="sex">性别</param> 55 /// <param name="longitude">经度</param> 56 /// <param name="latitude">纬度</param> 57 /// <param name="total">总数</param> 58 /// <param name="limit">限制输出数量</param> 59 /// <param name="maxDistance">最大半径</param> 60 /// <returns></returns> 61 public static List<UserInfo> GetNearbyUser(int myuid,int sex, double longitude, double latitude, ref int total, int limit = 1000, int maxDistance = 50*1000) 62 { 63 List<UserInfo> list = null; 64 try 65 { 66 list = new List<UserInfo>(); 67 double radius = 6378000; 68 MongoCollection<NearInfo> collection = Instance.GetCollection<NearInfo>("userinfo"); 69 70 #region 方法2 计算出了距离 71 IMongoQuery query = Query.NE("userid",myuid);//查询多行数据时要把自己排除出去 72 if (sex ==0 || sex == 1) { 73 query =Query.And( Query.NE("sex", 1-sex),Query.NE("userid",myuid));//业务需求 74 } 75 GeoNearOptionsBuilder options = GeoNearOptions.SetMaxDistance(maxDistance * 1.0 / radius).SetSpherical(true).SetDistanceMultiplier(radius);//设置最大半径和输入球体的周长 76 var result = collection.GeoNear(query, longitude, latitude, limit, options);//如果是查询所有用户,则将query赋值为query.null 77 78 var response = result.Response; 79 foreach (var item in response["results"].AsBsonArray) 80 { 81 BsonDocument bson = item.AsBsonDocument; 82 var dis = bson["dis"].AsDouble;//间隔的距离 83 var obj = bson["obj"].AsBsonDocument; 84 NearInfo info = BsonSerializer.Deserialize<NearInfo>(obj); 85 if (info == null) 86 continue; 87 /*将反序列的数据赋值到对应的类实例中*/ 88 UserInfo tmp = new UserInfo { 89 data1 = value1, 90 data2 = value2,
93 ...
94 }; 95 list.Add(tmp); 96 total++; 97 //CLog.WriteLog(info.sex.ToString()); 98 } 99 CLog.WriteLog(myuid+"Read: "+result.Response.ToJson()); 100 #endregion 101 //CLog.WriteLog(list.ToJson()); 102 } 103 catch (Exception ex){ 104 CLog.WriteLog(ex.Message);//同更新用户的方法一致,使用log并throw异常 105 } 106 return list; 107 }
108 }
本来不想写那么详细的,考虑到这篇文章并非深入探寻mongodb对于.net的可持久化操作实现,就把能注意的东西填上避免其他人多走弯路了。
引用或转载此文档请务必添加原文链接或地址。谢谢