Redis——数据结构

Redis的五种基本数据类型:String、Hash、List、Set、ZSet

|--------|------------------------|-------------------------------------------------------------------------|
| 结构类型 | 结构存储值 | 结构读写能力 |
| String | 字符串、整数或浮点数 | 对整个字符串或字符串的一部分进行操作;对整数或者浮点数进行自增或自减操作 |
| List | 链表,每个节点上包含一个字符串 | 对链表两端进行push或pop操作 ,读取单个或多个元素;根据值查找或删除元素 |
| Set | 包含字符串的无序集合 | 字符串集合,包含基础的存在判断、增删改查,还包含计算交集、差集等 |
| Hash | 包含键值对的无序散列 | 可增删改单个元素 |
| Zset | 有序集合,value外关联一个分数,用于排序 | 字符串成员与双精度浮点数分数的有序映射 ;元素的排列顺序由分数的大小决定;包含增删改单个元素以及根据分值范围或者成员来获取元素 |

随着Redis的更新,后来又增加了四种数据类型:BitMap、HyperLoglog、GEO、Stream。

各类型的应用场景:

  • String:缓存对象、常规计数、分布式锁、共享session信息等。
  • List:消息队列(需要自己实现全局唯一ID,以消费组形式消费数据)
  • Hash:缓存对象
  • Set:聚合计算(并集、交集、差集)场景,比如点赞、共同关注、抽奖活动等。
  • Zset:排序场景
  • BitMap:二值状态统计的场景,比如签到、判断用户登录状态、连续签到用户总数等。
  • HyperLogLog(2.8 版新增):海量数据基数统计的场景,比如百万级网页 UV 计数等;
  • GEO(3.2 版新增):存储地理位置信息的场景,比如滴滴叫车;
  • Stream(5.0 版新增):消息队列,相比于基于 List 类型实现的消息队列,有这两个特有的特性:自动生成全局唯一消息ID,支持以消费组形式消费数据。

Zset使用示例:

添加元素并赋值分数

bash 复制代码
# arcticle:1 文章获得了200个赞
> ZADD user:xiaolin:ranking 200
 arcticle:1
(integer) 1
# arcticle:2 文章获得了40个赞
> ZADD user:xiaolin:ranking 40
 arcticle:2
(integer) 1
# arcticle:3 文章获得了100个赞
> ZADD user:xiaolin:ranking 100
 arcticle:3
(integer) 1
# arcticle:4 文章获得了50个赞
> ZADD user:xiaolin:ranking 50
 arcticle:4
(integer) 1
# arcticle:5 文章获得了150个赞
> ZADD user:xiaolin:ranking 150
 arcticle:5
(integer) 1

对某个文章的赞进行自增操作

bash 复制代码
 ZINCRBY user:xiaolin:ranking 1 arcticle:4
"51"

查看某篇文章的分数

bash 复制代码
ZSCORE user:xiaolin:ranking arcticle:4
"50"

获取对应分数区间内的文章

bash 复制代码
ZRANGEBYSCORE user:xiaolin:ranking 100 200
 WITHSCORES
1) "arcticle:3"
2) "100"
3) "arcticle:5"
4) "150"
5) "arcticle:1"
6) "200"

Zset底层原理:

存储小数据量是使用ziplist(压缩列表)

压缩列表底层:连续两个节点存储分数和value,新增元素时使用插入排序

示例:[socre1][value1][score2][value2]...

存储大数据量时使用跳表+Hash表

跳表的实现原理:

跳表有多个层级,每次添加新元素时会通过随机算法获取0到1的随机数,如果随机数<0.25(概率小于25),则增加一层,然后继续随机生成随机数,直到随机数大于0.25结束。层高最大限制为64。

相关推荐
qq_3923971238 分钟前
Redis常用操作
数据库·redis·wpf
一只叫煤球的猫2 小时前
真实事故复盘:Redis分布式锁居然失效了?公司十年老程序员踩的坑
java·redis·后端
一只fish2 小时前
MySQL 8.0 OCP 1Z0-908 题目解析(17)
数据库·mysql
花好月圆春祺夏安3 小时前
基于odoo17的设计模式详解---装饰模式
数据库·python·设计模式
A__tao3 小时前
SQL 转 Java 实体类工具
java·数据库·sql
m0_653031363 小时前
腾讯云认证考试报名 - TDSQL数据库交付运维专家(TCCE PostgreSQL版)
运维·数据库·腾讯云
小马哥编程4 小时前
【iSAQB软件架构】架构决策记录-ADR
数据库·架构·系统架构·设计规范
萧鼎4 小时前
深度探索 Py2neo:用 Python 玩转图数据库 Neo4j
数据库·python·neo4j
m0_653031365 小时前
腾讯云认证考试报名 - TDSQL数据库交付运维专家(TCCE MySQL版)
运维·数据库·腾讯云
power 雀儿5 小时前
集群聊天服务器---MySQL数据库的建立
服务器·数据库·mysql