redis 五种数据结构常用操作命令详解(String,list,set,zset,hash)

本文涉及的产品
云数据库 Tair(兼容Redis),内存型 2GB
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
简介: 🍅程序员小王的博客:程序员小王的博客🍅 欢迎点赞 👍 收藏 ⭐留言 📝🍅 如有编辑错误联系作者,如果有比较好的文章欢迎分享给我,我会取其精华去其糟粕🍅java自学的学习路线:

redis 五种数据结构总结目录


Redis 是完全开源的,遵守 BSD 协议,是一个高性能的 key-value 数据库。


Redis 与其他 key - value 缓存产品有以下三个特点:


Redis支持数据的持久化,可以将内存中的数据保存在磁盘中,重启的时候可以再次加载进行使用。


Redis支持数据的备份,即master-slave模式的数据备份。


Redis不仅仅支持简单的key-value类型的数据,同时还提供list,set,zset,hash等数据结构的存储。


   String——字符串

   Hash——字典

   List——列表

   Set——集合

   ZSet——有序集合


一、String常见命令

string 是 redis 最基本的类型,你可以理解成与 Memcached 一模一样的类型,一个 key 对应一个 value。


string 类型是二进制安全的。意思是 redis 的 string 可以包含任何数据。比如jpg图片或者序列化的对象。


string 类型是 Redis 最基本的数据类型,string 类型的值最大能存储 512MB。


1、内存存储模型

0.png


2、常用操作命令

image.png


3、常规命令具体实现

(1)设置/获取一个值

image.png

1.png


(2)设置多个值/获取多个值

image.png


2.png

60.png


(3)获取原始的key值,设置新值

image.png

3.png


(4)获取key对应的值的长度

image.png

4.png


(5)给key对应的值的追加值

image.png

5.png


(6)截取value的内容

image.png

6.png


(7)创建并且设置key存活的时间(用来做秒杀之类的)

image.png

7.png

8.png


(8)存在不做任何操作,不存在添加一个或多个值

image.png

9.png


(9)对字符串中是数值的减少(如果不是数值,如:"12a"就不能执行改操作)

decrease 减少

image.png

10.png


(10)对字符串中是数值(包含小数点)的增加(如果不是数值,如:"12a"就不能执行改操作)

Increment:自增

image.png

11.png


二、List类型

// list类型 元素有序 且 可以重复

1.内存存储模型

12.png


2.常用操作指令

image.png


3、具体实现

(1)lpush将某个值加入到一个key列表头部

倒序排序,先进去的在后面
lpush users whj yfj zs li ww


13.png


(2)lpushx同lpush,但是必须要保证这个key存在

127.0.0.1:6379> lpushx names win7
127.0.0.1:6379> lrange names 0 -1
1) "win7"
2) "whj"
3) "yfj"
4) "zs"
5) "li"
6) "ww"

14.png

15.png


(3)rpush|将某个值加入到一个key列表末尾

127.0.0.1:6379> lrange users 0 -1
杨福君
zx
dzw
lfk
whx
zxj
yfj
whj
王恒杰
127.0.0.1:6379> rpush users 杨福君
10
127.0.0.1:6379> lrange users 0 -1
杨福君
zx
dzw
lfk
whx
zxj
yfj
whj
王恒杰
杨福君


16.png


(4)rpushx同rpush,但是必须要保证这个key存在

127.0.0.1:6379> rpushx names whj
0
127.0.0.1:6379> rpushx users whj
11
127.0.0.1:6379> lrange users 0 -1
杨福君
zx
dzw
lfk
whx
zxj
yfj
whj
王恒杰
杨福君
whj

17.png


(5)lpop返回和移除列表左边的第一个元素

127.0.0.1:6379> lrange users 0 -1
zx
dzw
lfk
whx
zxj
yfj
whj
王恒杰
杨福君
whj
127.0.0.1:6379> lpop users
zx
127.0.0.1:6379> lrange users 0 -1
dzw
lfk
whx
zxj
yfj
whj
王恒杰
杨福君
whj

18.png


(6)rpop返回和移除列表右边的第一个元素

从右边弹出来四个
127.0.0.1:6379> lrange users 0 -1
dzw
lfk
whx
zxj
yfj
whj
王恒杰
杨福君
whj
127.0.0.1:6379> rpop users
whj
127.0.0.1:6379> rpop users
杨福君
127.0.0.1:6379> rpop users
王恒杰
127.0.0.1:6379> rpop users
whj
127.0.0.1:6379> lrange users 0 -1
dzw
lfk
whx
zxj
yfj

19.png


(7)lrange获取某一个下标区间内的元素

lpush users whj yfj dzw zx whx zxj


20.png

(8)llen获取列表元素个数

llen users

21.png


(9)lset设置某一个指定索引的值(索引必须存在)

lset users 3 lhh


22.png

(10)lindex获取某一个指定索引位置的元素

lindex users 3


23.png

(11)lrem删除重复元素

rpush users whj


 lrem users 2 whj

25.png


(12)ltrim 保留列表中特定区间内的元素

ltrim users 0 3


26.png

(13)linsert、在某一个元素之前,之后插入新元素

linsert users before whx whj


在某个元素之前添一个数

27.png

  • 在某个数之后添加一个数
linsert users  after zx lfk

28.png


三、Set类型

key String

vlaue Set集合类型 元素不能存在重复 元素无序 String

特点: Set类型 Set集合 元素无序 不可以重复


1.内存存储模型

29.png


2.常用命令

image.png


(1)sadd:为集合添加元素(无序,自动去重)

sadd names 王恒杰 杨福君周宣君 邓正武 吴洪旭 张茜


30.png

(2)smebers:显示集合中所有元素 无序(member:成员)

smembers names

31.png


(3)scard:返回集合中元素的个数

scard names


33.png

(4)spop:随机返回一个元素 并将元素在集合中删除

spop names


(5)smove:从一个set集合中向另一个set集合移动元素 必须是同一种类型

smove names goodfriend 邓正武

36.png


(6)srem:从集合中删除一个元素

srem names 吴洪旭

37.png

(7)sismeber:判断一个集合中是否含有这个元素(sis=sister姐妹)

sismember names 张茜


(8)srandmember:随机返回元素(srand:乐趣,根据自己的乐趣返回值)

srandmember names 1

39.png


(9)sdiff:去掉第一个集合中其它集合含有的相同元素 (不会操作原始集合元素)

sdiff names goodfriend

40.png

(10)sinter:求交集(intersection:交集)

sinter names goodfriend

41.png


(11)sunion:求和集(union:合集)

sunion names goodfriend

42.png


四、 ZSet类型 SortSet可排序SET

ZSET

特点: 1.不可重复 2.可排序的set集合 根据元素分数进行排序

key String

value ZSET

值=分数+值

1.内存模型

43.png


2.常用命令

image.png


(1)zadd:添加一个有序集合元素

zadd schoolreport 30 杨福君 50 邓正武 70 吴洪旭 100 王恒杰

(2)zcard:返回集合的元素个数

zcard schoolreport

44.png


(3)zrange 升序 zrevrange 降序:返回一个范围内的元素

  • 返回升序排名zrange
zadd schoolreport 30 杨福君 50 邓正武 70 吴洪旭 100 王恒杰
zrange schoolreport 0 -1


45.png


  • 返回倒序排名(reverse:反转)zrevrange

(4)zrangebyscore:按照分数查找一个范围内的元素 (实现分页)

zrevrange schoolreport 0 -1


46.png


47.png


(5)zrank:返回排名

zrank  schoolreport 王恒杰

48.png

(6)zrevrank:倒序排名

zrevrank schoolreport 王恒杰

50.png


(7)zscore:显示某一个元素的分数

zscore  schoolreport 王恒杰

51.png


(8)zrem:移除某一个元素

zrem  schoolreport 吴洪旭

52.png


(9)zincrby:给某个特定元素加分/减分

  • 给某个特定元素加分
zincrby schoolreport 30 杨福君

53.png


  • 给某个特定元素减分
zincrby schoolreport -2 杨福君

54.png


(9)zset实现分页

zrangebyscore schoolreport 0 100 withscores limit 0 2

55.png


五、hash类型 Map<String,String>

key:String

value: Map<String,String>

特点: value 是一个map结构 存在key value key 无序的


(1)内存模型

56.png


(2)常用命令

image.png


(3)常规命令具体实现

1、hset|设置一个key/value对

2、hget|获得一个key对应的value

3、hgetall|获得所有的key/value对

57.png


4、hdel|删除某一个key/value对

5、hexists|判断一个key是否存在

58.png


6、hkeys|获得所有的key

7、hvals|获得所有的value

59.png


8、hmset|设置多个key/value

9、hmget|获得多个key的value

61.png


10、hsetnx|设置一个不存在的key的值

62.png


11、hincrby|为value进行加法运算

63.png


12、hincrbyfloat|为value加入浮点值

64.png



相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore &nbsp; &nbsp; ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库&nbsp;ECS 实例和一台目标数据库&nbsp;RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&amp;RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
相关文章
|
20天前
|
存储 缓存 安全
只会“有序无序”?面试官嫌弃的List、Set、Map回答!
小米,一位热衷于技术分享的程序员,通过与朋友小林的对话,详细解析了Java面试中常见的List、Set、Map三者之间的区别,不仅涵盖了它们的基本特性,还深入探讨了各自的实现原理及应用场景,帮助面试者更好地准备相关问题。
55 20
|
2月前
|
存储 消息中间件 NoSQL
Redis数据结构:List类型全面解析
Redis数据结构——List类型全面解析:存储多个有序的字符串,列表中每个字符串成为元素 Eelement,最多可以存储 2^32-1 个元素。可对列表两端插入(push)和弹出(pop)、获取指定范围的元素列表等,常见命令。 底层数据结构:3.2版本之前,底层采用**压缩链表ZipList**和**双向链表LinkedList**;3.2版本之后,底层数据结构为**快速链表QuickList** 列表是一种比较灵活的数据结构,可以充当栈、队列、阻塞队列,在实际开发中有很多应用场景。
|
3月前
|
NoSQL 关系型数据库 MySQL
Redis 列表(List)
10月更文挑战第16天
40 2
|
3月前
|
消息中间件 存储 监控
redis 的List类型 实现 排行榜
【10月更文挑战第8天】
48 2
|
3月前
|
存储 分布式计算 NoSQL
大数据-40 Redis 类型集合 string list set sorted hash 指令列表 执行结果 附截图
大数据-40 Redis 类型集合 string list set sorted hash 指令列表 执行结果 附截图
29 3
|
2月前
|
C语言
【数据结构】栈和队列(c语言实现)(附源码)
本文介绍了栈和队列两种数据结构。栈是一种只能在一端进行插入和删除操作的线性表,遵循“先进后出”原则;队列则在一端插入、另一端删除,遵循“先进先出”原则。文章详细讲解了栈和队列的结构定义、方法声明及实现,并提供了完整的代码示例。栈和队列在实际应用中非常广泛,如二叉树的层序遍历和快速排序的非递归实现等。
226 9
|
2月前
|
存储 算法
非递归实现后序遍历时,如何避免栈溢出?
后序遍历的递归实现和非递归实现各有优缺点,在实际应用中需要根据具体的问题需求、二叉树的特点以及性能和空间的限制等因素来选择合适的实现方式。
37 1
|
2月前
|
存储 缓存 算法
在C语言中,数据结构是构建高效程序的基石。本文探讨了数组、链表、栈、队列、树和图等常见数据结构的特点、应用及实现方式
在C语言中,数据结构是构建高效程序的基石。本文探讨了数组、链表、栈、队列、树和图等常见数据结构的特点、应用及实现方式,强调了合理选择数据结构的重要性,并通过案例分析展示了其在实际项目中的应用,旨在帮助读者提升编程能力。
60 5
|
2月前
|
存储 算法 Java
数据结构的栈
栈作为一种简单而高效的数据结构,在计算机科学和软件开发中有着广泛的应用。通过合理地使用栈,可以有效地解决许多与数据存储和操作相关的问题。
|
2月前
|
存储 JavaScript 前端开发
执行上下文和执行栈
执行上下文是JavaScript运行代码时的环境,每个执行上下文都有自己的变量对象、作用域链和this值。执行栈用于管理函数调用,每当调用一个函数,就会在栈中添加一个新的执行上下文。