Redis的三种特殊数据类型

本文涉及的产品
服务治理 MSE Sentinel/OpenSergo,Agent数量 不受限
简介: 【1月更文挑战第6天】Redis的三种特殊数据类型

文章目录

一、Redis geospatial 地理位置

二、Redis Hyperloglog 基数统计的算法

三、Redis Bitmaps 位存储(0、1)

总结


一、Redis geospatial 地理位置

  • 1.geoadd:将指定的地理空间位置(纬度、经度、名称)添加到指定的key中。
geoadd china:city 121.472644 31.231706 shanghai
geoadd china:city 120.619585 31.299379 suzhou
geoadd china:city 116.405285 39.904989 beijing
geoadd china:city 113.280637 23.125178 guangzhou 113.26197 23.10379 haizhuqu

往china:city这个key里,添加了5个地方的经纬度:上海、苏州、北京、广州、广州海珠区。

  • 2.geopos:从key里返回所有给定位置元素的位置(经度和纬度)。
geopos china:city suzhou shanghai

返回位置的坐标。返回位置的坐标。

  • 3.geodist:返回两个给定位置之间的距离。如果两个位置之间的其中一个不存在, 那么命令返回空值。

单位:

- m 表示单位为米(默认)。

- km 表示单位为千米。

- mi 表示单位为英里。

- ft 表示单位为英尺。

geodist china:city suzhou shanghai km

返回两地的距离

  • 4.georadius:以给定的经纬度为中心, 返回键包含的位置元素当中, 与中心的距离不超过给定最大距离的所有位置元素。
georadius china:city 121.49295 31.22337 30 km

我以 上海黄浦区的坐标121.49295 31.22337为中心,寻找30km之内的城市。

再远点,100km之内,还可以找到suzhou,加上withdist显示出距离。

georadius china:city 121.49295 31.22337 100 km withdist

再加上count,只返回我指定的数量。

georadius china:city 121.49295 31.22337 100 km withdist withcoord count 1
  • 5.georadiusbymember:这个命令和 georadius命令一样, 都可以找出位于指定范围内的元素。但是这里不是指定中心点坐标,而是指定以哪个元素为中心点。
georadiusbymember china:city suzhou 100 km withdist

这里以元素suzhou为中心点,找周围100km内的其他元素。

  • 6.geohash:一个或多个位置元素,用hash表示。
geohash china:city suzhou shanghai

返回11个字符的Geohash字符串,代表当前经纬度的字符串,就是换了个形式,将二维的经纬度转化成了一个一维的字符串。如果2个字符串越接近,则2个位置距离也越近

geo的底层原理还是zset,我们可以使用zset命令操作geo,比如移除geo里的城市。

zrem china:city haizhuqu

二、Redis Hyperloglog 基数统计的算法

基数:一个集合中的不重复元素的个数。

优点:占用的内存是固定的,2^64不同的元素的技术,只需要废12KB内存!如果要从内存角度来比较的话 Hyperloglog 首选!

实例:网页的UV(一个人访问一个网站多次,但还是算作一个人)

  • 1.PFadd:创建元素
PFadd mykey a b c d e f
  • 2.PFCOUNT:统计key元组元素的基数数量
PFCOUNT mykey
  • 3.PFMERGE:合并两组元组
PFMERGE mykey3 mykey mykey2

错误率:0.81%,如果允许容错,那么可以选择Hyperloglog。

三、Redis Bitmaps 位存储(0、1)

Bitmaps 位图,数据结构!都是操作二进制位来进行记录,就只有0和1两个状态!

365天= 365 bit1字节= 8bit 46个字节左右!

  • SETBIT key offset value
    对key存储的字符串,设置或者清除指定偏移量上的位(bit),位的设置或者清除取决于value参数,0/1;当key不存在时,自动生成一个新的字符串。字符串会进行伸展确保value保存在指定的偏移量上。字符串进行伸展时,空白位置以0填充。
    offset 范围:

0~2^32

  • 返回值:
    指定偏移量原来存储的位
  • GETBIT key offset
    获取指定偏移量上的位(bit),当offset比字符串长度大,或者key不存在,返回0;
    返回值:
    字符串值指定偏移量上的位(bit)
  • BITCOUNT key [start] [end]
    计算给定字符串中,被设置为1的bit位的数量。start和end参数可以指定查询的范围,可以使用负数值。-1代表最后一个字节,-2代表倒是第二个字节。
    注意:start和end是字节索引,因此每增加1 代表的是增加一个字符,也就是8位,所以位的查询范围必须是8的倍数。
    返回值:
    被设置为1的位的数量

总结

以上就是Redis的三种特殊数据类型,希望对你有所帮助

相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore     ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库 ECS 实例和一台目标数据库 RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
相关文章
|
1月前
|
存储 消息中间件 NoSQL
Redis数据类型详解:选择合适的数据结构优化你的应用
Redis数据类型详解:选择合适的数据结构优化你的应用
|
3天前
|
SQL NoSQL Java
Redis数据类型 Hash Set Zset Bitmap HyperLogLog GEO
Redis数据类型 Hash Set Zset Bitmap HyperLogLog GEO
14 0
|
7天前
|
存储 NoSQL 定位技术
Redis常用数据类型及常用命令
这些是Redis中常用的数据类型和命令。Redis还提供了许多其他命令和功能,用于数据存储、操作和查询。你可以根据需要选择适当的数据类型和命令来满足你的应用程序需求。
21 4
|
4月前
|
SQL NoSQL 定位技术
Redis基本命令和常用数据类型
Redis基本命令和常用数据类型
139 0
|
16天前
|
存储 SQL NoSQL
Redis入门到通关之五大基本数据类型及其使用场景
Redis入门到通关之五大基本数据类型及其使用场景
17 0
|
17天前
|
存储 NoSQL Redis
第十八章 Redis查看配置文件和数据类型
第十八章 Redis查看配置文件和数据类型
20 0
|
1月前
|
存储 SQL NoSQL
Redis的数据类型
Redis的数据类型
19 0
|
1月前
|
存储 XML NoSQL
Redis支持哪些数据类型?
Redis提供五种数据类型:String(支持JSON、XML等序列化,最大512MB),Hash(键值对,适合存储对象),List(有序列表,可在两端添加元素),Set(无序唯一元素集合),以及Sorted Set(有序集合,元素带分数排序)。每种类型有特定应用场景,优化了数据操作效率。
10 0
|
2月前
|
存储 消息中间件 NoSQL
Redis 常见数据类型(对象类型)和应用案列
接下来,让我们走进 Redis 的对象世界,Redis 5.0版本就已经支持了下面的 9 种类型,分别是 :字符串对象、列表对象、哈希对象、集合对象、有序集合对象、Bitmaps 对象、HyperLogLog 对象、Geospatial 对象、Stream对象。
Redis 常见数据类型(对象类型)和应用案列
|
2月前
|
存储 NoSQL Redis
Redis新数据类型-Bitmaps
Redis新数据类型-Bitmaps