我正在尝试使用 Mysql 和 PostgresSQL 中的空间函数来计算两个位置之间的距离。我从谷歌获取了纬度和经度。详情如下
位置一 - 纬度:42.260223;经度:-71.800010
位置二 - 纬度:42.245647;经度:-71.802521
使用的 SQL 查询:
选择距离(GEOMFROMTEXT('点(42.260223 -71.800010)'),GEOMFROMTEXT('点(42.245647 -71.802521)'))
两个数据库给出相同的结果 0.014790703059697。但是当我在其他系统中计算距离时,结果是不同的。请参考以下链接
= 1.44 英里
= 1.53 英里
所以我想知道我的计算方法/查询是否正确。如果是错误的,那么查询数据库距离的正确方法是什么。
简单的答案是使用半正矢公式。这假设地球是一个球体,但事实并非如此,但这并不是一个糟糕的近似。本演示文稿中描述了这一点以及许多其他细节:
http://www.scribd.com/doc/2569355/Geo-Distance-Search-with-MySQL http://www.scribd.com/doc/2569355/Geo-Distance-Search-with-MySQL
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)