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','121.47','31.23','shanghai');
$redis->rawCommand('geoadd','114.30','30.60','wuhan');
echo '<pre>';
//获取两个地理位置的距离,单位:m(米,默认), km(千米), mi(英里), ft(英尺)
var_dump($redis->rawCommand('geodist','beijing','wuhan'));
var_dump($redis->rawCommand('geodist','shanghai','km'));
//获取成员的经纬度
var_dump($redis->rawCommand('geopos','shanghai'));
//获取成员的经纬度hash,geohash表示坐标的一种方法,便于检索和存储
var_dump($redis->rawCommand('geohash','wuhan'));
//基于经纬度坐标的范围查询
//查询以经纬度为114,30为圆心,100千米范围内的成员
var_dump($redis->rawCommand('georadius','114','30','100','km'));
//WITHCOORD表示获取成员经纬度
var_dump($redis->rawCommand('georadius','km','WITHCOORD'));
//WITHDIST表示获取到圆心的距离
var_dump($redis->rawCommand('georadius','WITHDIST'));
//WITHHASH表示获取成员经纬度HASH值
var_dump($redis->rawCommand('georadius','WITHHASH'));
//COUNT 数量,表示限制获取成员的数量
var_dump($redis->rawCommand('georadius','COUNT','3'));
// ASC 根据圆心位置,从近到远的返回元素
// DESC 根据圆心位置,从远到近的返回元素
var_dump($redis->rawCommand('georadius','ASC'));
//基于成员位置范围查询
//查询以武汉为圆心,100千米范围内的成员
var_dump($redis->rawCommand('georadiusbymember','wuhan','km'));
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。