最近由于项目需求需要使用mongodb建立一个空间数据库,开始一直没有解决空间索引和空间查询的问题 过了很久才发现是数据格式的问题,mongodb并不会自动将json字符串数据转换为bson,需要手动转化,这是一个很有用的函数可以帮上忙,fromjson(),这个函数可以直接将json格式的数据转化为bson格式,
string json=pogeometry->exportToJson();
BSONObj tbson=fromjson(json);
在建立索引的时候有一个问题一直没有解决,就是如果坐标超出了[-180,180)怎么办,这个值是mongodb的默认值,在shell操作时可以通过min,max对其索引范围进行修改,但是c++driver中似乎没有发现有关于min和max的代码,以下是我建立索引的代码:
if (i=="2d")
{
m_DBClientConnection.ensureIndex(m_strdatabaseName+"."+m_strCollectionName,BSON("coordinates"<<"2d"),false,"",true,false,-1,0);
}
else
{m_DBClientConnection.ensureIndex(m_strdatabaseName+"."+m_strCollectionName,BSON("coordinates"<<"2dsphere"),false,"",true,false,-1,0);}
空间查询中,开始不知道对于不同的查询方式能够返回的值是有区别的,后来在操作手册上发现确实是有区别的,只有一部分操作能返回点线面,其他的只能返回点。
具体可以看这个网址http://docs.mongodb.org/manual/referen