查询5公里范围内门店

$mylat = $data['lat'];

$mylng = $data['lng'];

$maxRange = db(\tname::config)->where('uid', WID)->value('location_range');

$where['2 * asin(sqrt(pow(sin((v.lat * pi() / 180 - '.$mylat.' * pi() / 180) / 2),2) + cos(v.lat * pi() / 180) * cos('.$mylat.' * pi() / 180) * pow(sin((v.lng * pi() / 180 - '.$mylng.' * pi() / 180) / 2),2))) * 6378.137'] = ['elt',$maxRange];

$nearPeopleList = $callingModel->alias('a')

    ->join('wechat_' . \tname::vip . ' v', 'v.openid=a.openid', 'left')

    ->field("a.*,2 * asin(sqrt(pow(sin((v.lat * pi() / 180 - $mylat * pi() / 180) / 2),2) + cos(v.lat * pi() / 180) * cos($mylat * pi() / 180) * pow(sin((v.lng * pi() / 180 - $mylng * pi() / 180) / 2),2))) * 6378.137 as distance")

    ->where($where)

    ->order('distance asc')

    ->paginate(10, false, ['page' => $data['page']])->each(function ($item, $key) use ($data) {

        $item['distance'] = round($item['distance'],2);

        return $item;

    });
当用经纬度写在where条件里面的时候,如果是联查表不可以用filed的别名区筛选,sql不识别,只能用$where['2 * asin(sqrt(pow(sin((v.lat * pi() / 180 - '.$mylat.' * pi() / 180) / 2),2) + cos(v.lat * pi() / 180) * cos('.$mylat.' * pi() / 180) * pow(sin((v.lng * pi() / 180 - '.$mylng.' * pi() / 180) / 2),2))) * 6378.137'] = ['elt',$maxRange];去判断

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要实现该功能,你需要进行以下操作: 1. 获取用户的收货地址和商家门店地址,并计算它们之间的距离。 2. 判断距离是否超出配送范围(5公里内),如果超出,则下单失败。 3. 如果距离在配送范围内,则允许下单。 在Java中,可以使用Google Maps API或其他地图API来获取地址之间的距离。以下是一个简单的示例代码: ```java import com.google.maps.GeoApiContext; import com.google.maps.GeocodingApi; import com.google.maps.model.GeocodingResult; import com.google.maps.model.LatLng; import com.google.maps.DistanceMatrixApi; import com.google.maps.DistanceMatrixApiRequest; import com.google.maps.model.DistanceMatrix; import com.google.maps.model.DistanceMatrixElement; public class Order { public static boolean placeOrder(String userAddress, String storeAddress) { // 设置Google Maps API密钥 GeoApiContext context = new GeoApiContext.Builder() .apiKey("YOUR_API_KEY") .build(); // 获取用户地址和商家门店地址的经纬度 GeocodingResult[] userResults = GeocodingApi.geocode(context, userAddress).await(); LatLng userLatLng = userResults[0].geometry.location; GeocodingResult[] storeResults = GeocodingApi.geocode(context, storeAddress).await(); LatLng storeLatLng = storeResults[0].geometry.location; // 计算用户地址和商家门店地址的距离 DistanceMatrixApiRequest request = DistanceMatrixApi.newRequest(context); DistanceMatrix matrix = request.origins(userLatLng) .destinations(storeLatLng) .await(); DistanceMatrixElement element = matrix.rows[0].elements[0]; int distance = element.distance.inMeters; // 判断距离是否超出配送范围 if (distance > 5000) { return false; // 下单失败 } else { return true; // 允许下单 } } } ``` 在上面的代码中,`placeOrder`方法接收用户地址和商家门店地址作为参数,并返回一个布尔值,表示是否允许下单。该方法使用Google Maps API来获取地址之间的距离,并根据距离判断是否超出配送范围。如果距离超出配送范围,则返回`false`,否则返回`true`。你可以在程序中调用该方法来实现限制配送范围的功能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值