首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Android SQLite查询我的位置与给定距离值之间的距离的行

Android SQLite查询我的位置与给定距离值之间的距离的行
EN

Stack Overflow用户
提问于 2012-03-21 03:54:55
回答 2查看 1.2K关注 0票数 0

我在Android中有一个SQLite数据库,其中有一个包含经度、纬度和其他列的表。现在,我希望获得距离小于或等于给定距离的所有记录。

例如,我知道我当前的坐标(lat,long),我想从我的表中获得与我最大距离为10 me的所有记录。

我在堆栈上找到了一些链接,但没有太可靠的链接。有没有人知道这个问题的优化解决方案?

我认为我可以得到纬度小于我的经度+距离大于纬度的所有记录,以及经度小于我的长距离大于长距离的所有记录。在这个查询之后,我应该检查一些不需要的记录,因为查询不只返回想要的记录。这是个好主意吗?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 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的一部分)。

票数 4
EN

Stack Overflow用户

发布于 2012-03-21 04:11:26

仅供记录,它可以是有用的。

我不知道你在尝试做什么,或者你是否有一个后端或服务器。但是,如果您有一台存储这些位置的服务器,您可以(也应该)使用MongoDB来存储它。它对地理空间信息有很大的支持。

下面是如何使用MongoDB执行所需操作的示例:http://www.mongodb.org/display/DOCS/Geospatial+Indexing#GeospatialIndexing-Querying

票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/9793919

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档