突然想起30年前在外包写代码,地理位置都是走php mysql来算。
代码语言:javascript复制<?php
// 初始化Redis
$redis = new Redis();
$redis->connect('127.0.0.1');
// 保存城市的Key
$key = 'china_city';
// (1).添加的全部城市信息
$allCity = [
['109.22', '32.51', '陕西安康'],
['114.109', '22.544', '广东深圳'],
['114.279', '30.573', '湖北武汉'],
['114.498', '38.042', '河北石家庄'],
];
foreach ($allCity as $val) {
$redis->geoadd($key, $val['0'], $val['1'], $val['2']);
}
// (2).计算两个城市的距离(单位km)
$distance = $redis->geodist($key, '陕西安康', '广东深圳', 'km');
echo "$distance" . PHP_EOL;
// (3).查询下陕西安康的经纬度
$location = $redis->geopos($key, '陕西安康');
print_r($location);
// (4).查询广东深圳的经纬度hash,hash方便查询和储存
$hash = $redis->geohash($key, '广东深圳');
print_r($hash);
// (5).我现在在陕西咸阳市,坐标是108.70641,34.32908,查询以我为圆心,周围500千米的城市
$citys = $redis->georadius($key, '108.70641', '34.32908', '500', 'km');
print_r($citys);
// (6).虽然上面我查询到了周围500千米的城市,但是我不知道它的经纬度,加个参数WITHCOORD就知道了
$citys = $redis->georadius($key, '108.70641', '34.32908', '500', 'km', ['WITHCOORD']);
print_r($citys);
// (7).虽然上面我查询到了周围500千米的城市名称和经纬度,但是我不知道我和他们的距离,加个参数WITHDIST就知道了
$citys = $redis->georadius($key, '108.70641', '34.32908', '500', 'km', ['WITHDIST']);
print_r($citys);
// (8).虽然上面我xxxxxx,但是我不知道他们的hash,加个参数WITHDIST就知道了
$citys = $redis->georadius($key, '108.70641', '34.32908', '500', 'km', ['WITHHASH']);
print_r($citys);
// (9).虽然上面我xxxxxx,但是我只想返回1个城市,相当于SQL limit 1,加个参数COUNT就行
$citys = $redis->georadius($key, '108.70641', '34.32908', '5000', 'km', ['COUNT' => 1]);
print_r($citys);
// (10).虽然上面我xxxxxx,但是我想把返回的城市进行排序,按照距离排序,加个参数DESC就行
$citys = $redis->georadius($key, '108.70641', '34.32908', '5000', 'km', ['DESC']);
print_r($citys);
// (11).虽然上面都会玩了,但是我想一次加多个参数,那你加吧老弟
$citys = $redis->georadius($key, '108.70641', '34.32908', '5000', 'km', ['DESC', 'WITHCOORD', 'WITHDIST']);
print_r($citys);
// (12).上面是我指定以指定范围为中心查询,我们还能以redis中的成员为中心查询
$citys = $redis->georadiusbymember($key,'陕西安康','1000','km');
print_r($citys);