87、Redis 的 value 所支持的数据类型(String、List、Set、Zset、Hash)---->List相关命令

Redis 的 value 所支持的数据类型(String、List、Set、Zset、Hash)---->List相关命令


List相关命令:是指value中的数据类型

启动redis服务器:
打开小黑窗:
C:\Users\JH>e:
E:>cd E:\install\Redis6.0\Redis-x64-6.0.14\bin
E:\install\Redis6.0\Redis-x64-6.0.14\bin>redis-server.exe redis.windows.conf

启动redis客户端:
小黑窗:redis-cli


Redis的数据类型(都是针对Redis的value而言)

redis和map差不多。
Map 只能保存在内存中,
redis可以保存在磁盘。

Redis的key都是String


value支持如下5种数据类型:

String: 最基本的数据类型,可保存任何的数据。
List: 元素是String的有序集合,集合内的元素可以重复。
Set: 元素是String的无序集合,集合内的数据不能重复。
Zset: 元素是String的有序集合,集合内的数据不能重复。
Hash: 也是key-value集合(类似Java的Map),key和value都是String类型的数据。这种类型主要用于保存对象。

Redis为不同数据类型提供了不同的操作命令,因此特定类型的数据需要使用对应类型的命令来执行操作。


List相关的命令

在这里插入图片描述
Redis 的 List 和 Java 的 List 是有些相似的,只不过 Redis 的 List 的元素都是String类型。
Redis的List最多可包含 2^32-1个元素,其实跟 Java 的 int 的取值范围有点像。
但是这里的2^32-1是表示list可以存储的具体的个数。

LPUSH key value [value …]: 向key对应List的左边(头部,索引较小一端)添加一个或多个元素。
因此通过该命令新增的元素的索引始终是0

LPUSHX key value: LPUSH的安全版本,仅当key对应的List存在时有效。

LINDEX key index: 获取key对应List的index处的元素。

LINSERT key BEFORE|AFTER pivot value: 在key对应List的pivot元素之前或之后插入新的value元素。
该命令要求被参照的元素、List都是存在,否则就会返回-1。

LLEN key: 返回key对应List的长度。

LPOP key: 弹出并返回key对应List的第一个元素(索引为0的元素)。

LRANGE key start stop: 获取key对应List中start到stop范围的元素。
此处的range会前后边界都包括了。

LREM key count value: 从key对应的List中删除count个value元素。
如果count大于0,则从左到右删除count个value元素;
如果count小于0,则从右到左删除count个value元素;
如果count等于0,则删除所有的value元素。

LSET key index value: 将key对应List的index处的元素改为value。

LTRIM key start stop: 修剪List:只保留key对应List的start到stop之间的元素。
此处的range会前后边界都包括了。

RPOP key: 弹出并返回key对应List的最后一个元素。

RPOPLPUSH source destination: 弹出source List的最后一个元素,添加到destination List的左边(头部),
并返回该元素。
如果destination对应的List不存在,该命令会创建一个新的List。

RPUSH key value [value …]: 向key对应List的右边(尾部)添加一个或多个元素。
因此通过该命令新增的元素的索引始终是长度-1

RPUSHX key value: RPUSH的安全版本,仅当key对应的List存在时有效。

BLPOP key [key… ] timeout: LPOP的阻塞版本。
弹出、并返回多个List的第一个元素,如果某个List没有元素,
该命令会阻塞进程,直到所有List都有元素弹出或超时。该命令的B代表Block。

BRPOP key [key ] timeout: RPOP的阻塞版本。弹出、并返回多个List的最后一个元素,
如果某个List没有元素,该命令会阻塞进程,直到所有List都有元素弹出或超时。

BRPOPLPUSH source destination timeout: RPOPLPUSH的阻塞版本,如果source中没有元素,该命令会阻塞进程,
直到source有元素弹出或超时。


演示

LPUSH key value [value …]: 向key对应List的左边(头部,索引较小一端)添加一个或多个元素。
因此通过该命令新增的元素的索引始终是0

注意: 在添加元素的时候,不要用逗号隔开,不然逗号会被认为是该元素的一部分,
比如 b1, b2 ----- 那么这个元素就是 【b1,】【b2】
在这里插入图片描述

LPUSHX key value: LPUSH的安全版本,仅当key对应的List存在时有效。
就是Redis要存在这个key才能添加list元素的操作。如图,reids中没有name这个key,所以无法添加该list集合及其元素。
在这里插入图片描述

RPUSH key value [value …]: 向key对应List的右边(尾部)添加一个或多个元素。
因此通过该命令新增的元素的索引始终是长度-1
在这里插入图片描述

RPUSHX key value: RPUSH的安全版本,仅当key对应的List存在时有效。
同理,要有这个key才能执行该操作,也可以说要往这个list添加元素,那么得先存在这个key-value。

LINDEX key index: 获取key对应List的index处的元素。
在这里插入图片描述

LINSERT key BEFORE|AFTER pivot value: 在key对应List的pivot元素之前或之后插入新的value元素。
该命令要求被参照的元素、List都是存在,否则就会返回-1。
在这里插入图片描述

LLEN key: 返回key对应List的长度。
在这里插入图片描述

LPOP key: 弹出并返回key对应List的第一个元素(索引为0的元素)。
在这里插入图片描述

LRANGE key start stop: 获取key对应List中start到stop范围的元素。
此处的range会前后边界都包括了。
在这里插入图片描述

LREM key count value: 从key对应的List中删除count个value元素。
如果count大于0,则从左到右删除count个value元素;
如果count小于0,则从右到左删除count个value元素;
如果count等于0,则删除所有的value元素。

在这里插入图片描述

LSET key index value: 将key对应List的index处的元素改为value。
在这里插入图片描述

LTRIM key start stop: 修剪List:只保留key对应List的start到stop之间的元素。
此处的range会前后边界都包括了。
在这里插入图片描述

RPOP key: 弹出(删除)并返回key对应List的最后一个元素。
在这里插入图片描述

RPOPLPUSH source destination: 弹出 source List的最后一个元素,添加到 destination List的左边(头部),
并返回该元素。
如果destination对应的List不存在,该命令会创建一个新的List。
在这里插入图片描述

BRPOPLPUSH source destination timeout: RPOPLPUSH的阻塞版本,如果source中没有元素,该命令会阻塞进程,
直到source有元素弹出或超时。

在这里插入图片描述

BLPOP key [key… ] timeout: LPOP的阻塞版本。
弹出、并返回多个List的第一个元素,如果某个List没有元素,
该命令会阻塞进程,直到所有List都有元素弹出或超时。该命令的B代表Block。

添加多个key,但是只弹出第一个key的数据

在这里插入图片描述

BRPOP key [key ] timeout: RPOP的阻塞版本。弹出、并返回多个List的最后一个元素,
如果某个List没有元素,该命令会阻塞进程,直到所有List都有元素弹出或超时。
在这里插入图片描述

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
在Java中使用Redis存放List集合,可以通过使用RedisList数据类型来实现。首先,你需要引入Redis的Java客户端库,如Jedis或Lettuce。然后,你可以使用客户端库提供的方法来操作Redis中的List数据类型。以下是一个示例代码来存放List集合到Redis中: 1. 首先,创建一个Redis连接对象: Jedis jedis = new Jedis("localhost", 6379); 2. 使用rpush方法将List集合存入RedisList<String> list = new ArrayList<>(); list.add("element1"); list.add("element2"); list.add("element3"); for (String element : list) { jedis.rpush("mylist", element); } 这将在Redis的键"mylist"下创建一个List,并将List集合中的元素依次存放到List中。 3. 使用lrange方法来获取Redis中的List集合: List<String> storedList = jedis.lrange("mylist", 0, -1); 这将返回存储在Redis中的List集合。 请注意,以上示例代码是使用Jedis客户端库,如果你使用的是Lettuce客户端库,操作方法可能会有所不同。另外,为了方便数据的序列化和反序列化,你可以使用JSON工具库将List集合转换为JSON字符串进行存储,然后再进行反序列化。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [【Redis】在java中的使用-存取list类型(附源码)](https://blog.csdn.net/qsbbl/article/details/83688723)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 33.333333333333336%"] - *2* [Python列表(List)的定义语法.md](https://download.csdn.net/download/qq_42431718/88241216)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 33.333333333333336%"] - *3* [java 用redisTemplate 的 Operations存取list集合](https://blog.csdn.net/weixin_30315723/article/details/101726536)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 33.333333333333336%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

_L_J_H_

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值