用mysql计算两个经纬度间的距离

之前不知道用mysql进行快捷计算,每次都是用的php方法去计算,都是先查出来然后循环去计算,如果需要用到排序后再进行分页,每次是全查,然后计算,排序后再进行二维数组分页,这样性能很差,才知道mysql可以计算

php计算
  /**
     * 求两个已知经纬度之间的距离,单位为km
     * @param lng1,lng2 经度 lat1,lat2 纬度
     * @param
     * @return float 距离,单位为km
     **/
    public static function getDistance($lat1, $lng1, $lat2, $lng2)
    {
        //将角度转为狐度
        $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))) * 6371;
        return round($s, 1);

    }
// mysql计算,解决了排序,和分页
SELECT
    id,
    latitude,
    longitude,
    (
        6371 *
        acos(
            cos(radians(目标纬度)) *
            cos(radians(latitude)) *
            cos(radians(longitude) - radians(目标经度)) +
            sin(radians(目标纬度)) * sin(radians(latitude))
        )
    ) AS distance
FROM
    locations
ORDER BY
    distance
LIMIT ....

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容