SQL 2座標距離計算後のソート
825 ワード
2つの座標の列が(x 1,y 1)、(x 2,y 2)である場合、それらの間の距離:
SQRT((X1-X2)*(X1-X2)+(Y1-Y2)*(Y1-Y2))
longitude経度
义齿
SQRT((X1-X2)*(X1-X2)+(Y1-Y2)*(Y1-Y2))
SELECT * FROM m_store
ORDER BY
SQRT((121.517759-`longitude`)*(121.517759-`longitude`)+(31.178469-`latitude`)*(31.178469-`latitude`))
longitude経度
义齿
/**
* ,
*@param lng1,lng2
*@param lat1,lat2
*@return float ,
*@author www.Alixixi.com
**/
function getdistance($lng1,$lat1,$lng2,$lat2){
//
$radLat1=deg2rad($lat1);//deg2rad()
$radLat2=deg2rad($lat2);
$radLng1=deg2rad($lng1);
$radLng2=deg2rad($lng2);
$a=$radLat1-$radLat2;
$b=$radLng1-$radLng2;
$s=2*asin(sqrt(pow(sin($a/2),2)+cos($radLat1)*cos($radLat2)*pow(sin($b/2),2)))*6378.137*1000;
return $s;
}
echo getdistance(121.477551,31.270338, 118.782347,32.072796).' ';