php使用redis的GEO地理信息類型


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

  


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM