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'));
