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

简介: 🍅程序员小王的博客:程序员小王的博客🍅 欢迎点赞 👍 收藏 ⭐留言 📝🍅 如有编辑错误联系作者,如果有比较好的文章欢迎分享给我,我会取其精华去其糟粕🍅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



相关文章
|
5月前
|
存储 消息中间件 NoSQL
【Redis】常用数据结构之List篇:从常用命令到典型使用场景
本文将系统探讨 Redis List 的核心特性、完整命令体系、底层存储实现以及典型实践场景,为读者构建从理论到应用的完整认知框架,助力开发者在实际业务中高效运用这一数据结构解决问题。
|
算法
你对Collection中Set、List、Map理解?
你对Collection中Set、List、Map理解?
204 18
你对Collection中Set、List、Map理解?
|
存储 JSON NoSQL
redis基本数据结构(String,Hash,Set,List,SortedSet)【学习笔记】
这篇文章是关于Redis基本数据结构的学习笔记,包括了String、Hash、Set、List和SortedSet的介绍和常用命令。文章解释了每种数据结构的特点和使用场景,并通过命令示例演示了如何在Redis中操作这些数据结构。此外,还提供了一些练习示例,帮助读者更好地理解和应用这些数据结构。
redis基本数据结构(String,Hash,Set,List,SortedSet)【学习笔记】
|
存储 分布式计算 NoSQL
大数据-40 Redis 类型集合 string list set sorted hash 指令列表 执行结果 附截图
大数据-40 Redis 类型集合 string list set sorted hash 指令列表 执行结果 附截图
177 3
|
算法
你对Collection中Set、List、Map理解?
你对Collection中Set、List、Map理解?
154 5
|
存储 Java 索引
Java 中 List、Set、Map 和 Queue 之间的区别
【8月更文挑战第22天】
495 0
|
存储 算法
非递归实现后序遍历时,如何避免栈溢出?
后序遍历的递归实现和非递归实现各有优缺点,在实际应用中需要根据具体的问题需求、二叉树的特点以及性能和空间的限制等因素来选择合适的实现方式。
344 59
|
8月前
|
编译器 C语言 C++
栈区的非法访问导致的死循环(x64)
这段内容主要分析了一段C语言代码在VS2022中形成死循环的原因,涉及栈区内存布局和数组越界问题。代码中`arr[15]`越界访问,修改了变量`i`的值,导致`for`循环条件始终为真,形成死循环。原因是VS2022栈区从低地址到高地址分配内存,`arr`数组与`i`相邻,`arr[15]`恰好覆盖`i`的地址。而在VS2019中,栈区先分配高地址再分配低地址,因此相同代码表现不同。这说明编译器对栈区内存分配顺序的实现差异会导致程序行为不一致,需避免数组越界以确保代码健壮性。
171 0
栈区的非法访问导致的死循环(x64)
|
存储 C语言 C++
【C++数据结构——栈与队列】顺序栈的基本运算(头歌实践教学平台习题)【合集】
本关任务:编写一个程序实现顺序栈的基本运算。开始你的任务吧,祝你成功!​ 相关知识 初始化栈 销毁栈 判断栈是否为空 进栈 出栈 取栈顶元素 1.初始化栈 概念:初始化栈是为栈的使用做准备,包括分配内存空间(如果是动态分配)和设置栈的初始状态。栈有顺序栈和链式栈两种常见形式。对于顺序栈,通常需要定义一个数组来存储栈元素,并设置一个变量来记录栈顶位置;对于链式栈,需要定义节点结构,包含数据域和指针域,同时初始化栈顶指针。 示例(顺序栈): 以下是一个简单的顺序栈初始化示例,假设用C语言实现,栈中存储
614 77