当前位置: 首页 > news >正文

87、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都有元素弹出或超时。
在这里插入图片描述

http://www.lryc.cn/news/178615.html

相关文章:

  • Celery结合flask完成异步任务与定时任务
  • 前端项目练习(练习-001-纯原生)
  • 基于微信小程序的游戏账号交易买卖平台设计与实现(源码+lw+部署文档+讲解等)
  • 2023 年 Bitget Wallet 测评
  • 医疗图像分割指标
  • 零代码编程:用ChatGPT批量修改文件夹名称中的大小写
  • webpack:详解cache模块常用配置
  • 云原生Kubernetes:Pod控制器
  • 数据库基础与MySQL入门
  • 探索Java爬虫框架:解锁网络数据之门
  • 智慧燃气平台的总体架构到底应怎样设计?
  • MonkeyRunner测试步骤
  • Konva基本处理流程和相关架构设计
  • 人工智能AI知多少?
  • leetcode1610. 可见点的最大数目(java)
  • Apache Flume
  • 【切片】基础不扎实引发的问题
  • CVE-2023-5129 libwebp堆缓冲区溢出漏洞影响分析
  • leetcode做题笔记155. 最小栈
  • 蓝海彤翔亮相2023新疆网络文化节重点项目“新疆动漫节”
  • 【AI视野·今日NLP 自然语言处理论文速览 第四十四期】Fri, 29 Sep 2023
  • 【VsCode】vscode创建文件夹有小图标显示和配置
  • celery分布式异步任务队列-4.4.7
  • 解决M2苹果芯片Mac无法安装python=3.7的虚拟环境
  • Sound/播放提示音, Haptics/触觉反馈, LocalNotification/本地通知 的使用
  • Oracle实现主键字段自增
  • 【C++数据结构】二叉树搜索树【完整版】
  • TouchGFX之字体缓存
  • windows系统关闭软件开机自启的常用两种方法
  • 巧用@Conditional注解根据配置文件注入不同的bean对象