日期:2014-05-18  浏览次数:20589 次

求在sql2005中,根据两点的经纬度计算距离的方法(解决立刻给分)
rt,解决立刻给分。

------解决方案--------------------
SQL code
select sqrt(POWER((经度1-经度2),2)+POWER((纬度1-纬度2),2))

------解决方案--------------------
1楼强大,

用平面解析几何中的两点距离公式.
------解决方案--------------------
勾股定理
------解决方案--------------------
SQL code
SQL SERVER 根据地图经纬度计算距离的公式



go 

--创建经纬度距离计算函数
 CREATEFUNCTION [dbo].[fnGetDistance] 

 --LatBegin 开始经度
 --LngBegin 开始维度
(@LatBegin REAL, @LngBegin REAL, @LatEnd REAL, @LngEnd REAL) 

       RETURNSFLOAT

       AS

BEGIN

       --距离(千米)

       DECLARE @Distance      REAL

       DECLARE @EARTH_RADIUS  REAL

       SET @EARTH_RADIUS = 6378.137 

       

       DECLARE @RadLatBegin  REAL,

               @RadLatEnd    REAL,

               @RadLatDiff   REAL,

               @RadLngDiff   REAL

       

       SET @RadLatBegin = @LatBegin *PI()/ 180.0 

       SET @RadLatEnd = @LatEnd *PI()/ 180.0 

       SET @RadLatDiff = @RadLatBegin - @RadLatEnd 

       SET @RadLngDiff = @LngBegin *PI()/ 180.0 - @LngEnd *PI()/ 180.0 

       

       SET @Distance = 2 *ASIN(

               SQRT(

                   POWER(SIN(@RadLatDiff / 2), 2)+COS(@RadLatBegin)*COS(@RadLatEnd) 

                   *POWER(SIN(@RadLngDiff / 2), 2)

               )

           )

       

       SET @Distance = @Distance * @EARTH_RADIUS 

       --SET @Distance = Round(@Distance * 10000) / 10000 

       

       RETURN @Distance

END

------解决方案--------------------
错了吧,地球近似圆,你算出来的是弦长,距离应该算弧吧。
------解决方案--------------------
要用 geography 数据类型来处理.
------解决方案--------------------
探讨
SQL code
SQL SERVER 根据地图经纬度计算距离的公式



go

--创建经纬度距离计算函数
CREATEFUNCTION [dbo].[fnGetDistance]

--LatBegin 开始经度
--LngBegin 开始维度
(@LatBegin REAL, @LngBegin REAL, @LatEnd REAL, @LngEnd RE……

------解决方案--------------------
SQL code
select (((ASIN((sqrt(POWER((经度1-经度2),2)+POWER((纬度1-纬度2),2)))/2)/6378.1))*2)/180)*((ASIN((sqrt(POWER((经度1-经度2),2)+POWER((纬度1-纬度2),2)))/2)/6378.1))*2)*6378.1