最近由于项目需求需要使用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);}