laravel 查询数据库计算坐标距离

distance 是计算出来的距离单位是公里

public function getDistance($lat="纬度", $lng="经度")
{

Dome1
$distance = "ACOS(SIN(( $lat * 3.1415) / 180 ) *SIN((lat * 3.1415) / 180 ) +COS(( $lat* 3.1415) / 180 ) * COS((lat * 3.1415) / 180 ) *COS(( $lng* 3.1415) / 180 - (lng * 3.1415) / 180 ) ) * 6380";
$list = $this->model->select('*')->addSelect(\DB::raw($distance . ' as distance'))->orderBy('distance', 'ASC')->get()->toArray();

 

Dome2
$model = DB::table('table_name')->select('');
$list = $model->addSelect(\DB::raw("acos(cos(" . $lat . "*pi()/180)*cos(lat*pi()/180)*cos(" . $lng . "*pi()/180-lng*pi()/180)+sin(" . $lat . "*pi()/180)*sin(lat * pi()/180)) * 6367000 AS distance"))->orderBy('distance','ASC')->get();

dd($list);
}


 

posted @ 2020-11-06 11:20  华诺  阅读(887)  评论(0编辑  收藏  举报