<?php $redis = new Redis(); $redis->connect('127.0.0.1', 6379, 60); $redis->auth(''); //添加成員的經緯度信息 $redis->rawCommand('geoadd', 'citys', '116.40', '39.90', 'beijing'); $redis->rawCommand('geoadd', 'citys', '121.47', '31.23', 'shanghai'); $redis->rawCommand('geoadd', 'citys', '114.30', '30.60', 'wuhan'); echo '<pre>'; //獲取兩個地理位置的距離,單位:m(米,默認), km(公里), mi(英里), ft(英尺) var_dump($redis->rawCommand('geodist', 'citys', 'beijing', 'wuhan')); var_dump($redis->rawCommand('geodist', 'citys', 'beijing', 'shanghai', 'km')); //獲取成員的經緯度 var_dump($redis->rawCommand('geopos', 'citys', 'shanghai')); //獲取成員的經緯度hash,geohash表示座標的一種方法,便於檢索和存儲 var_dump($redis->rawCommand('geohash', 'citys', 'shanghai', 'wuhan')); //基於經緯度座標的範圍查詢 //查詢以經緯度爲114,30爲圓心,100公里範圍內的成員 var_dump($redis->rawCommand('georadius', 'citys', '114', '30', '100', 'km')); //WITHCOORD表示獲取成員經緯度 var_dump($redis->rawCommand('georadius', 'citys', '114', '30', '100', 'km', 'WITHCOORD')); //WITHDIST表示獲取到圓心的距離 var_dump($redis->rawCommand('georadius', 'citys', '114', '30', '100', 'km', 'WITHDIST')); //WITHHASH表示獲取成員經緯度HASH值 var_dump($redis->rawCommand('georadius', 'citys', '114', '30', '100', 'km', 'WITHHASH')); //COUNT 數量,表示限制獲取成員的數量 var_dump($redis->rawCommand('georadius', 'citys', '114', '30', '100', 'km', 'COUNT', '3')); // ASC 根據圓心位置,從近到遠的返回元素 // DESC 根據圓心位置,從遠到近的返回元素 var_dump($redis->rawCommand('georadius', 'citys', '114', '30', '100', 'km', 'ASC')); //基於成員位置範圍查詢 //查詢以武漢爲圓心,100公里範圍內的成員 var_dump($redis->rawCommand('georadiusbymember', 'citys', 'wuhan', '100', 'km'));