坐標(biāo) 多種數(shù)據(jù)庫計(jì)算GPS經(jīng)緯度坐標(biāo)距離

mysql計(jì)算GPS經(jīng)緯度距離

DELIMITER $$

CREATEDEFINER=`root`@`localhost` FUNCTION`getDistance`(

lon1 float(10,7)

,lat1 float(10,7)

,lon2 float(10,7)

,lat2 float(10,7)

) RETURNSdouble

begin

declared double;

declareradius int;

setradius = 6378140; #假設(shè)地球?yàn)檎蛐?,直徑?378140米

setd = (2*ATAN2(SQRT(SIN((lat1-lat2)*PI()/180/2)

*SIN((lat1-lat2)*PI()/180/2)+

COS(lat2*PI()/180)*COS(lat1*PI()/180)

*SIN((lon1-lon2)*PI()/180/2)

*SIN((lon1-lon2)*PI()/180/2)),

SQRT(1-SIN((lat1-lat2)*PI()/180/2)

*SIN((lat1-lat2)*PI()/180/2)

+COS(lat2*PI()/180)*COS(lat1*PI()/180)

*SIN((lon1-lon2)*PI()/180/2)

*SIN((lon1-lon2)*PI()/180/2))))*radius;

returnd;

end

sqlServer計(jì)算GPS經(jīng)緯度距離

SET ANSI_NULLS ON

GO

SET QUOTED_IDENTIFIER ON

GO

CREATE FUNCTION [dbo].[getDistance](@lng1 FLOAT,@lat1 FLOAT,@lng2 FLOAT,@lat2 FLOAT)

RETURNS FLOAT

AS

BEGIN

? ? ? ? DECLARE @Distance? ? ? FLOAT

? ? ? ? DECLARE @EARTH_RADIUS? FLOAT

? ? ? ? SET @EARTH_RADIUS = 6378140

? ? ? ? DECLARE @RadLatBegin? FLOAT,

? ? ? ? ? ? ? ? @RadLatEnd? ? FLOAT,

? ? ? ? ? ? ? ? @RadLatDiff? FLOAT,

? ? ? ? ? ? ? ? @RadLngDiff? FLOAT

? ? ? ? SET @RadLatBegin = @lat1 *PI()/ 180.0

? ? ? ? SET @RadLatEnd = @lat2 *PI()/ 180.0

? ? ? ? SET @RadLatDiff = @RadLatBegin - @RadLatEnd

? ? ? ? SET @RadLngDiff = @lng1 *PI()/ 180.0 - @lng2 *PI()/ 180.0

? ? ? ? SET @Distance = 2 *ASIN(

? ? ? ? ? ? ? ? SQRT(

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

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

? ? ? ? ? ? ? ? )

? ? ? ? ? ? )

? ? ? ? SET @Distance =ROUND(@Distance * @EARTH_RADIUS,1)

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

? ? ? ? RETURN @Distance

END

Oracle計(jì)算GPS經(jīng)緯度距離

create or replace FUNCTION GET_DISTANCE

(

? LNG1 IN NUMBER,

? LAT1 IN NUMBER,

? LNG2 IN NUMBER,

? LAT2 IN NUMBER

) RETURN NUMBER IS

? DISTANCE NUMBER:=0;

? PI NUMBER:=3.141592625;

? EARTH_RADIUS NUMBER :=6378140;

? RADLATBEGIN NUMBER :=LAT1*PI/180.0;

? RADLATEND NUMBER :=LAT2*PI/180.0;

? RADLATDIFF NUMBER :=RADLATBEGIN-RADLATEND;

? RADLNGDIFF NUMBER :=LNG1*PI/180.0-LNG2*PI/180.0;

BEGIN

? DISTANCE:=2*ASIN(SQRT(POWER(SIN(RADLATDIFF/2),2)+COS(RADLATBEGIN)*COS(RADLATEND)*POWER(SIN(RADLNGDIFF/2),2)));

? DISTANCE:=ROUND(DISTANCE*EARTH_RADIUS,1);

? RETURN DISTANCE;

END GET_DISTANCE;

PHP計(jì)算GPS經(jīng)緯度坐標(biāo)

<?php

functionrad($d){

return$d* 3.1415926535898 / 180.0;

}

functionGetDistance($lat1, $lng1, $lat2, $lng2){

$EARTH_RADIUS= 6378.137;

$radLat1= rad($lat1);

$radLat2= rad($lat2);

$a= $radLat1- $radLat2;

$b= rad($lng1) - rad($lng2);

$s= 2 * asin(sqrt(pow(sin($a/2),2) + cos($radLat1)*cos($radLat2)*pow(sin($b/2),2)));

$s= $s*$EARTH_RADIUS;

$s= round($s* 10000) / 10000;

return$s;

}

echoGetDistance(116.480733,39.98684,117.480733,39.98684);

?>

————————————————

版權(quán)聲明:本文為CSDN博主「_yuki_」的原創(chuàng)文章,遵循 CC 4.0 BY-SA 版權(quán)協(xié)議,轉(zhuǎn)載請(qǐng)附上原文出處鏈接及本聲明。

原文鏈接:https://blog.csdn.net/qq_19707521/article/details/70800933

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

友情鏈接更多精彩內(nèi)容