如何按距离排序 php,php做附近的人,根据距离由近到远进行排序

用户登陆的时候会获取到该用户的经纬度,数据库中存有所有用户的经纬度,如何进行由近到远进行排序,并算出距离

回复内容:

用户登陆的时候会获取到该用户的经纬度,数据库中存有所有用户的经纬度,如何进行由近到远进行排序,并算出距离

可以考虑用GeoHASH实现,效率更高,参考这篇http://www.cnblogs.com/LBSer/p/3310455.html

我觉得是时候把这个地址贴上来了。

https://segmentfault.com/q/1010000000345194

用php+redis可以实现 可以参考这个 http://www.wubiao.info/401

PHP安装GeoIP扩展和数据库根据IP获取访客所在国家/城市/经纬度等信息

然后就可以用geoip_record_by_name($_SERVER['REMOTE_ADDR'])获取用户经纬度.

注意:geoip_record_by_name()返回的西经和南纬是负数.

5000米转成经纬度:

纬度 Latitude: 1 deg = 110852 m

经度 Longitude: 1 deg = 111320*cos(lat) m

同一经线上,相差一纬度约为 110852 米

同一纬线上,相差一经度约为 111320*cos(lat) 米 (lat为该纬线的纬度)

($lat-$y) and lat < ($lat+$y) and

lon > ($lon-$x) and lon < ($lon+$x);

';

这个范围是一个粗略的范围,后面距离计算后把超过5公里的用户筛掉即可.

根据上面查询出来的用户的经纬度,

用半正矢公式根据经纬度计算两点间距离:

elasticsearch 得距离搜索,获取最近的20公里数据

GET test/test/_search

{

"query": {

"filtered": {

"query" : {

"match_all" : {}

},

"filter": {

"geo_distance": {

"distance": 20,

"distance_unit": "km",

"location": {

"lat" : 40.11116,

"lon" : -71.34115

}

}

}

}

}

}

相关标签:php

本文原创发布php中文网,转载请注明出处,感谢您的尊重!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值