会飞De琥珀

会飞De琥珀

MSSQL 根据经纬度查询距离

ALTER FUNCTION [GetDistance]
( 
    @GPSLng DECIMAL(12,6),
    @GPSLat DECIMAL(12,6),
    @Lng  DECIMAL(12,6),
    @Lat DECIMAL(12,6)
)
RETURNS DECIMAL(12,4)
AS
BEGIN
   DECLARE @result DECIMAL(12,4)
   SELECT @result=6371.004*ACOS(SIN(@GPSLat/180*PI())*SIN(@Lat/180*PI())+COS(@GPSLat/180*PI())*COS(@Lat/180*PI())*COS((@GPSLng-@Lng)/180*PI()))
   RETURN @result
END



SELECT *,GetDistance(当期点的经度,当期点的纬度,经度字段,纬度字段) AS dis FROM TABLENAME   WHERE dis<5

查找数据库中5公里内的记录


注:

6371.004  地球半径

6371.004*ACOS(SIN(@GPSLat/180*PI())*SIN(@Lat/180*PI())+COS(@GPSLat/180*PI())*COS(@Lat/180*PI())*COS((@GPSLng-@Lng)/180*PI()))  计算公式 可查球面弧长计算公式的详细解释



原文:http://www.cnblogs.com/drinkoJam/p/3594416.html

阅读更多
个人分类: SQL
想对作者说点什么? 我来说一句

没有更多推荐了,返回首页

加入CSDN,享受更精准的内容推荐,与500万程序员共同成长!
关闭
关闭