我有一个位置(纬度和经度).如何获取在我所在位置的10英里范围内部分或全部的邮政编码清单?
该解决方案可以是对一个众所周知的Web服务(google maps,bing maps等)或本地数据库解决方案(客户端具有sql server 2005)或算法的调用.
我看到有些similar question,但是所有的答案在很大程度上涉及使用sql Server 2008地理功能,这是不可用的.
解决方法
首先,您需要一个所有邮政编码及其对应纬度和经度的数据库.在澳大利亚,只有几千个(信息很容易获得),但是我认为这在美国可能比较困难.
其次,给你知道你在哪里,你知道你要找的半径,你可以查找那个半径范围内的所有邮政编码.用PHP编写的简单说明如下:(抱歉不在C#中)
function distanceFromTo($latitude1,$longitude1,$latitude2,$longitude2,$km){ $latitude1 = deg2rad($latitude1); $longitude1 = deg2rad($longitude1); $latitude2 = deg2rad($latitude2); $longitude2 = deg2rad($longitude2); $delta_latitude = $latitude2 - $latitude1; $delta_longitude = $longitude2 - $longitude1; $temp = pow(sin($delta_latitude/2.0),2) + cos($latitude1) * cos($latitude2) * pow(sin($delta_longitude/2.0),2); $earth_radius = 3956; $distance = $earth_radius * 2 * atan2(sqrt($temp),sqrt(1-$temp)); if ($km) $distance = $distance * 1.609344; return $distance; }