Redis 常用基本命令

devtools/2024/12/22 20:18:33/
查看所有键

keys命令可用于查看所有键,语法如下
pattern用于匹配key,其中*表示任意个任意字符

keys pattern

键总数
dbsize可用于查看键的总数,语法如下

dbsize

判断键是否存在
exists命令可用于判断一个键是否存在,语法如下

exists key

删除键
del可用于删除指定键,语法如下
返回值为删除键的个数,若删除一个不存在的键,则返回0。

del key [key ...]

查询键的剩余过期时间

ttl key

数据库管理命令
Redis默认有编号为0~15的16个逻辑数据库,每个数据库之间的数据是相互独立的,所有连接默认使用的都是0号数据库
切换数据库
select命令可用于切换数据库,语法如下

  • 若index超出范围,会报错
select index

清空数据库
flushdb命令会清空当前所选用的数据库,flushall命令会清空0~15号所有的数据库

string

Redis中的string类型保存的是字节序列(Sequence of bytes),因此任意类型的数据,只要经过序列化之后都可以保存到Redis的string类型中,包括文本、数字甚至是一个对象
set
set命令用于添加string类型的键值对,具体语法如下

SET key value [NX|XX] [EX seconds|PX milliseconds]

各选项含义如下

  • NX:仅在key不存在时set
  • XX:仅在key存在时set
  • EX seconds:设置过期时间,单位为秒
  • PX milliseconds:设置过期时间,单位为毫秒

get
get命令用于获取某个string类型的键对应的值,具体语法如下

GET key

incr
incr命令用于对数值做自增操作,具体语法如下

  • 若key对应的value是整数,则返回自增后的结果,若不是整数则报错,若key不存在则创建并返回1。
INCR key

decr
decr命令用于对数值做自减操作,具体语法如下
若key对应的value是整数,则返回自减后的结果,若不是整数则报错,若key不存在则创建并返回-1。
应用场景
string类型常用于缓存、计数器等场景。

DECR key
list类型

添加元素
向列表中添加元素的命令有lpush、rpush 、linsert,各命令的功能与用法如下
lpush
该命令用于向list左侧添加元素,语法如下

lpush key element [element ...]
示例
lpush l1 a b c

rpush
该命令用于向list右侧添加元素,语法如下

rpush key element [element ...]

linsert
该命令用于向list指定位置添加元素,语法如下

linsert key before|after pivot element
示例
linsert l1 after b new

查询元素
查询list元素的命令有lindexlrange,各命令的功能与用法如下

  • lindex
    该命令用于获取指定索引位置的元素,语法如下
  • index从左到右依次是0,1,2…,从右到左依次是-1,-2,-3…
lindex key index

lrange
该命令用于获取指定范围内的元素列表,语法如下

lrange key start stop
示例
获取list全部元素,命令如下
lrange l1 0 -1


删除list元素的命令有lpop、rpop、lrem,各命令的功能与用法如下
lpop
该命令用于移除并返回list左侧元素,语法如下

lpop key [count]

rpop
该命令用于移除并返回list右侧的元素,语法如下

rpop key [count]

lrem
该命令用于移除list中的指定元素,语法如下

lrem key count element

count参数表示要移除element元素的个数(list中可以存在多个相同的元素),count的用法

  • 若count>0,则从左到右删除最多count个element元素
  • 若count<0,则从右到左删除最多count(的绝对值)个element元素
  • 若count=0,则删除所有的element元素

修改元素
lset命令可用于修改指定索引位置的元素,语法如

lset key index element

llen命令可用于查看list长度,语法如下

llen key
  • 社交应用中,可使用list缓存每个用户发布的最新的N条记录。
  • list可用作异步消息队列。
set类型

add
该命令用于向set中添加元素,语法如下

  • smembers
    该命令用于查询set中的全部元素,语法如下
smembers key
  • srem
    该命令用于移除set中的指定元素,语法如下
srem key member [member ...]
  • spop
    该命令随机移除并返回set中的n个元素,语法如下
spop key [count]
  • srandmember
    该命令随机返回set中的n个元素(不删除),语法如下
srandmember key [count]
  • scard(Cardinality,基数)
    该命令用于查询set中的元素个数,语法如下
scard key
  • sismember
    该命令用于元素是否在set中,语法如下
sismember key element
  • sismember
    该命令用于元素是否在set中,语法如下
sismember key element
``

sinter
该命令用于计算多个集合的交集,语法如下

sinter key [key ...]

sunion
该命令用于计算多个集合的并集,语法如下

sunion key [key ...]

sdiff
该命令用于计算多个集合的差集,语法如下

sdiff key [key ...]

set可用于计算共同关注好友,随机抽奖系统等等。

hash类型

hash类型类似于Java语言中的HashMap,可用于存储键值对。
hset
该命令用于向hash中增加键值对,语法如下
hset
该命令用于向hash中增加键值对,语法如下

hset key field value [field value ...]

hget
该命令用于获取hash中某个键对应的值,语法如下

hget key field

hdel
该命令用于删除hash中的指定的键值对,语法如下

hdel key field [field ...]

hlen
该命令用于查询hash中的键值对个数,语法如下

hlen key

hexists
该命令用于判断hash中的某个键是否存在,语法如下

hexists key field

hkeys
该命令用于返回hash中所有的键,语法如下

hkeys key

hvals
该命令用于返回hash中所有的值,语法如下

hvals key

hgetall
该命令用于返回hash中所有的键与值,语法如下

hgetall key

hash类型可用于缓存对象等。

zset类型

zset(sorted set)被称为有序集合,同set相似,zset中也不会包含相同元素,但不同的是,zset中的元素是有序的。并且zset中的元素并非像list一样按照元素的插入顺序排序,而是按照每个元素的分数(score)排序。
zadd
该命令用于向zset中添加元素,语法如下

ZADD key [NX|XX] score member

zcard
该命令用于计算zset中的元素个数,语法如下

zcard key

zscore
改名用于查看某个元素的分数,语法如下

zscore key member
  • zrank/zrevrank
    这组命令用于计算元素的排名,其中zrank按照score的升序排序,zrevrank则按照降序排序,语法如下
zrank/zrevrank key member

**说明:**名次从0开始。

  • zrem
    该命令用于删除元素,语法如下
zrem key member [member ...]
  • zincrby
    该命令用于增加元素的分数,语法如下
zincrby key increment member
  • zrange
    该命令用于查询指定区间范围的元素,语法如下
zrange key start stop [byscore] [rev] [limit offset count] [withscores]

说明:

  • start/stop:用于指定查询区间,但是在不同模式下,其代表的含义也不相同
    • 默认模式下,start~stop表示的是名次区间,且该区间为闭区间。名次从0开始,且可为负数,-1表示倒数第一,-2表示倒数第二,以此类推。
    • byscore模式下(声明了byscore参数),则start~stop表示的就是分数区间,该区间默认仍为闭区间。在该模式下,可以在startstop前增加(来表示开区间,例如(1 (5,表示的就是(1,5)这个开区间。除此之外,还可以使用-inf+inf表示负无穷和正无穷。
  • byscore:用于切换到分数模式
  • rev:表示降序排序。在byscore模式下使用rev参数需要注意查询区间,start应大于stop。
  • limit:该选项只用于byscore模式,作用和sql语句中的limit一致
  • withscores:用于打印分数

http://www.ppmy.cn/devtools/44591.html

相关文章

微服务实践k8sdapr开发部署调用

前置条件 安装docker与dapr: 手把手教你学Dapr - 3. 使用Dapr运行第一个.Net程序安装k8s dapr 自托管模式运行 新建一个webapi无权限项目 launchSettings.json中applicationUrl端口改成5001,如下: "applicationUrl": "http://localhost:5001" //Wea…

大模型时代的具身智能系列专题(五)

stanford宋舒然团队 宋舒然是斯坦福大学的助理教授。在此之前&#xff0c;他曾是哥伦比亚大学的助理教授&#xff0c;是Columbia Artificial Intelligence and Robotics Lab的负责人。他的研究聚焦于计算机视觉和机器人技术。本科毕业于香港科技大学。 主题相关作品 diffusio…

阮一峰的ES6文档(第一天)

目录 ECMAScript 6简介 let和const命名 let基本用法-块级作用域 不存在变量提升 不允许重复声明 暂时性死区 为什么需要块级作用域&#xff1f; 原因一&#xff1a;内层变量可能会覆盖外层变量 原因二&#xff1a;用来计数的循环遍历泄露为全局变量 const基本用法-声明…

在做题中学习(62):矩阵区域和

1314. 矩阵区域和 - 力扣&#xff08;LeetCode&#xff09; 解法&#xff1a;二维前缀和 思路&#xff1a;读题画图才能理解意思&#xff1a;dun点点的是mat中的一个数&#xff0c;而要求的answer同位置的数 以点为中心上下左右延长 k 个单位所围成长方形的和。 因为最后answ…

【C++】---二叉搜索树

【C】---二叉搜索树 一、二叉搜索树概念二、二叉搜索树操作&#xff08;非递归&#xff09;1.二叉搜索树的查找 &#xff08;非递归&#xff09;&#xff08;1&#xff09;查找&#xff08;2&#xff09;中序遍历 2.二叉搜索树的插入&#xff08;非递归&#xff09;3.二叉搜索树…

Java-常用模块

文章目录 日期时间stream流 日期时间 jdk8新的日期时间类 解析和格式化DateTimeFormatter类&#xff08;线程安全&#xff09; LocalDateTime类 Instant类 Duration类String time "2013-02-11 11:00:00";DateTimeFormatter dateTimeFormatter DateTimeFormatter.o…

「大数据」Lambda架构

Lambda架构是一种用于处理大数据的架构,它由Twitter的前工程师Nathan Marz提出。Lambda架构的核心思想是将数据系统分为三个层次,以实现高容错性、低延迟和可扩展性。以下是Lambda架构的详细描述: 核心功能: 批处理层(Batch Layer):负责存储和管理主数据集,预先批处理计…

8. CSS弹性布局基础

第8章 弹性布局基础 CSS3引入了一个强大的布局模块——弹性布局&#xff08;Flexbox&#xff09;&#xff0c;它提供了一种更加高效、直观的方式来排列和对齐元素&#xff0c;使复杂布局的实现变得更加简单。本章将详细介绍弹性布局的基本概念和属性&#xff0c;并通过具体示例…