Redis教程(十):Redis中三种特殊数据类型命令

一、Geospatial

Geospatial是地理位置类型,我们可以用来查询附近的人、计算两人之间的距离等。

新增:

复制代码
geoadd city 106.54041 29.40268 chongqing 118.8921 31.32751 nanjing 117.30794 31.79322 hefei 102.82147 24.88554 kunming 91.13775 29.65262 lasa 116.23128 40.22077 beijing 

查看集合key:

复制代码
ZRANGE city 0 -1

查看指定位置:

复制代码
geopos city nanjing

查看多个指定位置:

复制代码
geopos city nanjing beijing

计算两个位置的距离:

复制代码
geodist city nanjing beijing

查看指定位置的1000公里范围内有哪些城市(111,45是经纬度):

复制代码
georadius city 111 45 1000 km

查看指定位置的1000公里范围内有哪些城市,返回带上经纬度:

复制代码
georadius city 120 38 1000 km withcoord

查看指定位置的1000公里范围内有哪些城市,返回带上距离和经纬度:

复制代码
georadius city 120 38 1000 km withcoord withdist

查看指定位置的1000公里范围内有哪些城市,返回带上距离和经纬度和哈希(哈希值越像则越近):

复制代码
georadius city 120 38 1000 km withcoord withdist withhash

查看指定位置的1000公里范围内有哪些城市,返回带上距离和经纬度和哈希(哈希值越像则越近),只返回两个:

复制代码
georadius city 120 38 1000 km withcoord withdist withhash count 2

查找指定元素指定范围内的元素:查询南京 500公里范围有哪些城市

复制代码
georadiusbymember city nanjing 500 km

返回北京和南京的经纬度的 hash值:

复制代码
geohash city beijing nanjing

删除一个位置:

复制代码
ZREM city lasa

二、Hyperloglog

Hyperloglog指的是基数,两个数据集中不重复的元素,在Redis中,会有一定的误差性。 官方给出的误差率是0.81% ,占用的内存是固定的,2^64个元素,相当于只需要12kb的内存即可。效率极高,网站的访问量,就可以利用Hyperloglog来进行计算统计!!

添加数据集:

复制代码
pfadd dataList 1 2 3 4 5 6 7

统计数据集中的元素:

复制代码
pfcount dataList

取并集:

复制代码
pfmerge newdata dataList dataList1  

三、Bitmap

Bitmap指的是位存储,操作二进制位来进行记录,就只有0 和 1 两个状态,可能需要我们统计用户的登陆信息,员工的打卡信息等等。只要是事务的只有两个状态的,我们都可以用Bitmap来进行操作。

添加:

复制代码
setbit login 1 1

获取:

复制代码
 getbit login 1

统计:

复制代码
bitcount login
相关推荐
dishugj3 分钟前
[ORACLE-RMAN]rman备份报错ORA-00245解决
数据库·oracle
herinspace3 分钟前
管家婆软件中如何运用商品副单位
运维·服务器·数据库·windows·电脑
TDengine (老段)7 分钟前
TDengine 统计函数 VARIANCE 用户手册
大数据·数据库·物联网·时序数据库·tdengine·涛思数据
前进的李工13 分钟前
SQL排序与分页查询技巧
开发语言·数据库·sql·mysql·oracle
gugugu.19 分钟前
MySQL 索引:核心原理、数据结构与优化实践
数据库·mysql
Fortune_yangyang20 分钟前
数据库基础
运维·网络·数据库·mysql
AI架构师易筋23 分钟前
RAG 与向量数据库是如何工作的:从图书馆比喻到系统架构
数据库
爬山算法27 分钟前
Redis(160)Redis的安全问题如何解决?
数据库·redis·安全
可可苏饼干27 分钟前
MySQL 索引
运维·数据库·学习·mysql