Redis 是一种基于内存的高性能键值对存储数据库,支持多种数据结构。以下是其最常用的五种数据结构及其特点和典型应用场景:
一. 字符串(String)
1、示例:
Hello,Wrold。
2、结构特点:
简单的键值对,值可以是字符串、整数或浮点数,支持二进制安全(可存储任意数据,如图像、序列化对象等)。
3、常用命令:
SET(设置值)、GET(获取值)、INCR(自增)、DECR(自减)、STRLEN(获取长度)等。
4、应用场景:
- 缓存简单数据(如用户信息、配置参数)。
- 计数器(如点赞数、访问量)。
- 分布式锁(利用 SETNX 命令实现原子性加锁)。
二. 列表(List)
1、示例:
a,b,c,d,c,d……
2、结构特点:
有序、可重复的字符串链表,支持从头部(左)或尾部(右)插入 / 删除元素,读取效率高。
3、常用命令:
LPUSH/RPUSH(左 / 右插入)、LPOP/RPOP(左 / 右弹出)、LRANGE(获取范围元素)、LLEN(获取长度)等。
4、应用场景:
- 消息队列(利用 RPUSH 和 LPOP 实现 FIFO 队列)。
- 微博、朋友圈等时间线(按发布顺序存储动态 ID)。
- 分页数据(如分页查询的结果缓存)。
三. 哈希(Hash)
1、示例:
username:jack;userpassword:jack123……
2、结构特点:
键值对的集合,类似于 Python 中的字典,用于存储对象的字段和值,适合存储结构化数据。
3、常用命令:
HSET/HGET(设置/获取字段值)、HGETALL(获取所有字段值)、HINCRBY(字段值自增)、HLEN(获取字段数)等。
4、应用场景:
- 存储用户信息(如姓名、年龄、邮箱等字段)。
- 缓存关系型数据库记录(减少数据库查询压力)。
- 购物车数据(商品 ID 作为字段,数量作为值)。
四. 集合(Set)
1、示例:
{a,b,c,d……}
2、结构特点:
无序、唯一的字符串集合,基于哈希表实现,支持快速去重和交集、并集、差集运算。
3、常用命令:
SADD(添加元素)、SISMEMBER(判断元素是否存在)、SMEMBERS(获取所有元素)、SINTER/SUNION/SDIFF(集合运算)等。
4、应用场景:
- 社交平台的关注 / 粉丝列表(判断用户是否关注某人)。
- 标签系统(如商品分类标签、用户兴趣标签)。
- 统计不重复元素数量(如独立访客数)。
五. 有序集合(Sorted Set,Zset)
1、示例:
{王五:78,张三:90,李四:95……}
2、结构特点:
有序、唯一的字符串集合,每个元素关联一个分数(Score),通过分数实现自动排序(升序或降序)。
3、常用命令:
ZADD(添加元素及分数)、ZRANGE(按排名范围获取元素)、ZREVRANGE(按逆序排名获取元素)、ZSCORE(获取元素分数)等。
4、应用场景:
- 排行榜(如游戏积分排名、商品销量排名)。
- 时间线排序(按时间戳分数存储动态,实现最新/最热排序)。
- 带有权重的任务队列(分数代表优先级)。
总结
Redis 的数据结构设计灵活且高效,每种结构适用于不同场景。选择合适的数据结构可以显著提升缓存性能和开发效率。除了上述五种,Redis 还支持位图(Bitmap)、HyperLogLog、地理空间(Geospatial)等高级数据结构,可根据具体需求扩展使用。