zoukankan      html  css  js  c++  java
  • 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'));
    

      

  • 相关阅读:
    arcgis要素折点转点
    arcgis问题数据判断
    arcgis根据位置信息查找一个点周围的线(根据交点,查找)
    GIS算法-最短路径-连通性-网络分析-路径规划
    Arcgis直连SQLServer数据库,通过REST修改数据ArcMap中更新数据库数据不更新,数据不统一
    None和NULL
    ArcPy属性查询
    WGS84转gcj02
    ArcGIS Server跨域
    MySQL中数据类型宽度有什么用, INT(11)有什么意义?
  • 原文地址:https://www.cnblogs.com/jkko123/p/10615905.html
Copyright © 2011-2022 走看看