我在Android中有一个SQLite数据库,其中有一个包含经度、纬度和其他列的表。现在,我希望获得距离小于或等于给定距离的所有记录。
例如,我知道我当前的坐标(lat,long),我想从我的表中获得与我最大距离为10 me的所有记录。
我在堆栈上找到了一些链接,但没有太可靠的链接。有没有人知道这个问题的优化解决方案?
我认为我可以得到纬度小于我的经度+距离大于纬度的所有记录,以及经度小于我的长距离大于长距离的所有记录。在这个查询之后,我应该检查一些不需要的记录,因为查询不只返回想要的记录。这是个好主意吗?
发布于 2012-03-21 04:00:42
你可能想分成两部分来做,
1)运行一个查询,在其中找到位于您所在位置的当前lat/lng的特定值+或-内的所有记录,where子句可能如下所示:
where (@latitude > (lat - .001)和@latitude > (lat - .001))和(@longitude> (lng- .001)和@longitude> (经度- .001))
2)根据上面的粗略结果,使用大圆/haversinse方法来确定每个位置之间的实际距离(大圆/haversinse已经是android地图api的一部分)。
发布于 2012-03-21 04:11:26
仅供记录,它可以是有用的。
我不知道你在尝试做什么,或者你是否有一个后端或服务器。但是,如果您有一台存储这些位置的服务器,您可以(也应该)使用MongoDB来存储它。它对地理空间信息有很大的支持。
下面是如何使用MongoDB执行所需操作的示例:http://www.mongodb.org/display/DOCS/Geospatial+Indexing#GeospatialIndexing-Querying
https://stackoverflow.com/questions/9793919
复制相似问题