redis3.2中增中了對GEO類型的支持,該類型存儲經緯度,提供了經緯設置,查詢,范圍查詢,距離查詢,經緯度hash等操作。
<?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'));