查询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];去判断

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值