Laravel附近的商店

Posted

技术标签:

【中文标题】Laravel附近的商店【英文标题】:Nearby stores in Laravel 【发布时间】:2016-11-26 10:23:07 【问题描述】:

我正在尝试在 Laravel 5.1 中获取 neraby 商店,我有可以计算坐标的地理编码解析器。但是我对haversine公式有疑问。基本上我需要从表 Aziende (Stores) 给定一个 lat, long e 类别通过 url 传递,获取附近的商店。

我尝试使用此代码:

$dove = Input::get('dove');
    $categoria_id = Input::get('id_categoria');
    // 4: check if any matches found in the database table 
    if (!empty($dove)) 
        $response = \GoogleMaps::load('geocoding')->setParamByKey ('address', $dove)->get();
        $response = json_decode($response, true);
        $latitude = $response['results'][0]['geometry']['location']['lat'];
        $longitude = $response['results'][0]['geometry']['location']['lng'];
        $radius = '5';
        $aziende  = DB::table('aziende')
            ->select(
                 ( 'lat * acos( cos( radians(50) ) * cos( radians( lat ) ) * cos( radians( lng ) - radians(-122) )
                       + sin( radians(37) ) * sin( radians( lat ) ) ) as distance') )->get();




     else 
    $aziende = DB::table("aziende")->where('categoria', $categoria_id)->get();
 
 ?>

【问题讨论】:

您使用的是什么数据库/版本?如果你使用 mysql,你有 ST_Distance...v5.7 有 ST_Distance_Sphere dev.mysql.com/doc/refman/5.7/en/… 【参考方案1】:

以下内容应该适用于您在 SQL 查询中实现半正弦公式。我的回答是假设你有一个模型设置来对应数据库表“aziende”。

$lat = floatval($response['results'][0]['geometry']['location']['lat']);
$lng = floatval($response['results'][0]['geometry']['location']['lng']);
$radius = 5;
$distance = DB::raw("*, ( 6371 * acos( cos( radians($lat) ) * cos( radians( lat ) ) * cos( radians( lng ) - radians($lng) ) + sin( radians($lat) ) * sin( radians( lat ) ) ) ) AS distance");
$aziende = Aziende::select($distance)->orderBy('distance')->where('distance', '<=', $radius)->get();

【讨论】:

以上是关于Laravel附近的商店的主要内容,如果未能解决你的问题,请参考以下文章

一般错误:Laravel 5.6.33 中的“)”附近的 1:语法错误“)

laravel 如何通过 long 和 lat 找到附近的地方

如何通过 Laravel 中的 API 从 Shopify 商店获取所有订单

将用户分配到 Laravel 关系中的任何商店?

Laravel 商店有不同的产品

如何为每个商店自动增加特定的数据库表值。 (Laravel 6)