首页 > 数据库 >#yyds干货盘点#一文了解Redis常用命令

#yyds干货盘点#一文了解Redis常用命令

时间:2023-12-16 18:01:10浏览次数:39  
标签:yyds set temp 示例 study 元素 Redis key 常用命令

本文包括Redis中常用的一些命令,包括针对所有的键相关的命令,以及5种常用数据类型:字符串、哈希、列表、集合以及有序集合的一些命令。

鉴于个人水平有限,文章中若有不对之处,烦请大家留言指正。

键相关

查看所有的键

keys会遍历所有的键,它的时间复杂度是O(n),因此当Redis保存了大量的键时,这个命令会非常耗时,因此生产环境下禁止使用该命令。

keys *
//初始化数据
study:0>set zhangsan 20
"OK"
study:0>get zhangsan
"20"
study:0>set lisi 25
"OK"
study:0>set wangwu 30
"OK"
//使用
study:0>keys *
 1)  "lisi"
 2)  "zhangsan"
 3)  "wangwu"

keys命令也支持模糊匹配,比如我们想获取所有以zhang开头的键,可以这样写:

keys zhang*
study:0>keys zhang*
 1)  "zhangsan"

获取键的总数

dbsize
study:0>dbsize
"3"

dbsize命令在计算键总数时不会遍历所有的键,而是直接获取Redis内置的键总数变量,所以dbsize命令的时间复杂度是O(1)

检查键是否存在

exists key

这个命令返回1或者0,1表示键存在,0表示键不存在

study:0>exists zhangsan
"1"
study:0>exists dalao
"0"

删除键

del key [key2, key3....]

这个命令返回删除成功的键总数,如果删除的键都不存在,则返回0

study:0>del zhangsan
"1"
study:0>del dalao
"0"

设置键的过期时间

Redis支持给键设置过期时间,当键过期后,该键会在Redis中被自动删除。

//初始化键
study:0>set hello world
"OK"
//给键设置50秒的过期时间
study:0>expire hello 50
"1"

设置过期时间之后,我们也可以通过ttl命令返回键的剩余过期时间,ttl命令有3种返回值:

  1. 大于等于0的整数:键的剩余过期时间
  2. -1表示键没有设置过期时间
  3. -2表示键不存在(有可能是最开始就不存在,有可能是键的过期时间到了被自动删除了)
study:0>ttl hello
"10"
study:0>ttl hello
"3"
study:0>ttl hello
"-2"

键的数据类型

type key
study:0>set hello world
"OK"
study:0>type hello
"string"

若key的类型是字符串类型,则返回string。若key的类型是列表类型,则返回list。

若key不存在,则返回none

study:0>type abc
"none"

字符串类型

设置值

set key value [ex seconds] [px milliseconds] [nx|xx]
study:0>set me water76016
"OK"

set命令的选项说明

  • ex seconds:为键设置秒级过期时间
  • px milliseconds:为键设置毫秒级过期时间
  • nx:键必须不存在才能设置成功,用于新增
  • xx:键必须存在才能设置成功,用于更新

其他set命令

Redis提供了setnx和setex两个命令,作用和ex和nx参数是一样的。

//命令格式
setex key seconds value
setnx key value
//setex使用范例(设置键为hello,20秒的过期时间)
study:0>setex hello 20 world
"OK"

//setnx使用范例(第一次键不存在设置成功,第二次键已经存在设置失败)
study:0>setnx me water76016
"1"
study:0>setnx me water76016
"0"

获取值

get key

如果获取的键不存在,则会返回null(空)

study:0>get me
"water76016"
study:0>get abcd
null

批量设置值

mset key value [key value ...]
//mset使用范例
study:0>mset one 1, two 2, three 3
"OK"

批量获取值

mget key1 [key2 key3]
//mget使用范例
study:0>mget one two three
 1)  "1,"
 2)  "2,"
 3)  "3"

Redis每次执行时中间需要耗费网络时间,使用批量操作有利用减少网络时间的损耗,但每次放入的批量操作的key不是无节制的,一次太多有可能导致Redis短时间阻塞。

计数

//key值自增1
incr key

//key值自减1
decr key

//自增指定数字
incrby key increment

//自减指定数字
incrby key decrment

下面以incr命令进行详细说明:

incr命令可以对值进行自增,使用该命令存在3种情况:

  1. 值如果不是整数,返回错误
  2. 值是整数,返回自增后的结果
  3. 键不存在,认为该键的初始化为0,会新增一个键进去,并返回1
//值不是整数示例
study:0>set hello world
"OK"
study:0>incr hello
"ERR value is not an integer or out of range"
//值是整数示例
study:0>set me 20
"OK"
study:0>incr me
"21"
//键不存在示例
study:0>get you
null
study:0>incr you
"1"
study:0>get you
"1"

哈希类型

设置值

hset key field value

如果设置成功,会返回 1。设置失败会返回0

//使用示例
study:0>hset user:1 one zhangsan
"1"

获取值

hget key field
//使用示例
study:0>hset user:1 one zhangsan
"1"
study:0>hget user:1 one
"zhangsan"

删除field

hdel命令支持同时删除多个field,返回的结果是删除成功的field的个数

hdel key field [field ...]
//使用示例
study:0>hdel user:1 one
"1"

批量设置和获取值

//批量设置值
hmset key field value [field value...]

//批量获取值
hmget key field [field2...]
//使用示例
study:0>hmset user:2 id 2 name zhangsan age 20
"OK"
study:0>hmget user:2 id name age
 1)  "2"
 2)  "zhangsan"
 3)  "20"

判断field是否存在

hexists key field
//使用示例
study:0>hexists user:2 id
"1"
study:0>hexists user:2 school
"0"

获取所有的field

hkeys key
//使用示例
study:0>hkeys user:2
 1)  "id"
 2)  "name"
 3)  "age"

获取所有的value

hvals key
//使用示例
study:0>hvals user:2
 1)  "2"
 2)  "zhangsan"
 3)  "20"

获取所有的field-value

注意事项:如果获取的值较多,有可能会阻塞Redis。如果获取部分值,可以使用hmget命令。如果一定要获取全部的键值,可以使用hscan命令,该命令会渐进式地获取所有的键值,并不是一次全部获取。

hgetall key
//使用示例
study:0>hgetall user:2
 1)  "id"
 2)  "2"
 3)  "name"
 4)  "zhangsan"
 5)  "age"
 6)  "20"

列表类型

Redis中的列表类型有两个特点,分别是:

  1. 列表中的元素是有序的
  2. 列表中的元素是可以重复的

添加元素

添加元素添加成功后,返回的是当前List中元素的总数

从右边添加元素

rpush key value [value...]
//添加元素示例
study:0>rpush my_list 1 2 3
"3"

从左边添加元素

lpush key value[value...]
//添加元素示例
study:0>lpush my_list 1 2 3
"6"

查找

获取指定范围内的元素

lrange key start end

注意,索引的下标从左到右分别是:0到N-1,但是从右到左是-1到-N。

//使用范例
study:0>lrange my_list 0 5
 1)  "3"
 2)  "2"
 3)  "1"
 4)  "1"
 5)  "2"
 6)  "3"

获取指定索引下标的元素

lindex key index
//使用示例
study:0>lindex my_list 3
"1"

获取列表长度

llen key
//使用示例
study:0>llen my_list
"6"

删除元素

从列表左侧弹出元素

lpop key
//使用示例
study:0>lpop my_list
"3"

从列表右侧弹出元素

rpop key
//使用示例
study:0>rpop my_list
"3"

删除指定元素

lrem key count value

lrem命令会从列表中找到等于value的元素进行删除,根据count的不同,可能存在以下3种情况:

  • count > 0。从左到右,删除最多count个元素
  • count < 0。从右到左,删除最多count个元素
  • count = 0。删除所有等于value的元素
//使用示例
study:0>lpush temp_list 3 3 3 3
"4"
study:0>lrem temp_list 1 3
"1"
study:0>lrem temp_list -1 3
"1"
study:0>lrem temp_list 0 3

保留指定索引范围的元素列表

ltrim key start end

列表的下标从0开始,这个命令会保留下标从start到end的所有元素。

//使用示例
study:0>lpush temp_list 1 2 3 4 5
"5"
study:0>ltrim temp_list 2 3
"OK"

修改元素

lset key index newValue
//使用示例
//修改列表的第一个元素为10
study:0>lset temp_list 0 10
"OK"
//查看列表的第一个元素是否为10,看是否修改成功
study:0>lindex temp_list 0
"10"
//设置的索引超过列表范围会报错
study:0>lset temp_list 10 100
"ERR index out of range"

阻塞操作

blpop key [key...] timeout
brpop key [key...] timeout

key [key...]表示可以同时传入多个键进行处理

timeout表示阻塞的超时时间。

blpop是从左弹出元素,brpop是从右弹出元素,两个除了弹出方向不同,其余基本相同。下面主要以brpop进行说明:

  1. 当列表为空的时候,加入timeout=3,那么客户端会等待3秒后进行返回。如果timeout=0。那么客户端会一直等待下去。
  2. 当列表不为空的时候,会立即返回相应的值
  3. 如果是多个键,那么brpop会从左到右遍历键,一旦某个键有元素,则立即返回
  4. 如果是多个客户端同时执行相同的阻塞命令,那么最先执行的那个客户端,可以获取到对应的值

集合类型

集合也是用来保存多个元素的,但其中的元素是无序的,并且不能够重复。

添加元素

sadd key element[element...]

返回结果是添加成功的元素个数

//使用示例
study:0>sadd temp_set 1 2 3 4 5
"5"

删除元素

srem key element [element...]

返回结果为成功删除元素的个数

//使用示例
study:0>sadd temp_set 1 2 3 4 5
"5"
study:0>srem temp_set 2 3
"2"

计算元素个数

scard key
//使用示例
study:0>scard temp_set
"3"

判断元素是否在集合中

sismember key element
//使用示例
study:0>sismember temp_set 3
"0"
study:0>sismember temp_set 1
"1"

随机返回元素

srandmember key [count]

srandmember命令会随机从集合中返回count个元素,如果count不填写,则默认为1

//使用示例
study:0>srandmember temp_set 2
 1)  "5"
 2)  "1"
study:0>srandmember temp_set
"1"

随机弹出元素

spop key

spop会随机从集合中弹出一个元素,并把该元素从集合中删除

//使用示例
study:0>spop temp_set
"1"

获取集合所有元素

smembers key
study:0>smembers temp_set
 1)  "4"
 2)  "5"

求多个集合的交集

sinter key [key2 key3...]

交集:顾名思义,就是每个集合所共有的元素。如果入参是2个集合,那么就是2个集合共同拥有的元素。如果入参是3个集合,那么入参就是3个集合共同拥有的元素

//使用示例
//集合one中具有元素1,one_two中具有元素1和2,three中具有元素3
study:0>sadd one 1
"1"
study:0>sadd one_two 1 2
"2"
study:0>sadd three 3
"1"
//取交集(one one_two three三个集合没有共同元素,返回空)
study:0>sinter one one_two three
//取交集(one two中具有共同元素,返回)
study:0>sinter one one_two
 1)  "1"

求多个集合的并集

sunion key [key2 key3...]

并集,顾名思义,就是每个集合所有的元素合并起来进行返回。示例和取交集类似,这里不再过多赘述。

求多个集合的差集

sdiff key [key2 key3...]

差集,就是取自身有,但其他人没有的那部分元素。如果传入多个集合,那么就是取自己有,但所有其他人都没有的那部分元素。大家理解意思即可,这里不再过多赘述。

有序集合

有序集合中的元素可以排序,但它并不是按索引下标进行排序,而是给每个元素都指定了一个分数,按照分数来进行排序。

有序集合中的元素不可以重复,但是分数是可以重复的。

添加元素

zadd key score member [score member...]
//使用示例
study:0>zadd class_grade 88 xiaoming
"1"

计算成员个数

zscard key
//使用示例
study:0>zcard class_grade
"1"

获取某个成员的分数

zscore key member
//使用示例
study:0>zscore class_grade xiaoming
"88"

计算成员的排名

//从低到高排名
zrank key member

//从高到低排名
zrerank key member

删除成员

zrem key member [member...]

增加某个成员的分数

zincrby key incrment member

标签:yyds,set,temp,示例,study,元素,Redis,key,常用命令
From: https://blog.51cto.com/u_11365839/8853353

相关文章

  • Redis数据结构8:REDIS_HASH
    REDIS_HASHHash本质上就是一个保存若干键值对的数据结构,类似于Java中的HashMap。同样的,hash中只能存在一个独一无二的key,所有的操作都围绕key展开。hash的最大优点在于其可以提供最佳O(1)的查询时间复杂度。通过一段原始数据key,通过特定算法将其哈希值转化为数组下标,通过相同的......
  • Git——常用命令
    1.第一次初始化gitinit  初始化仓库gitadd.gitcommit-m‘firstcommit’[email protected]:帐号名/仓库名.gitgitpulloriginmastergitpushoriginmaster#-f强推[email protected]:git帐号名/仓库名.git 2.基本操作gitche......
  • Redis集群
    集群由于数据量过大,单个Master复制集难以承担,因此需要对多个复制集进行集群,形成水平扩展每个复制集只负责存储整个数据集的一部分,这就是Redis的集群,其作用是提供在多个Redis节点间共享数据的程序集。Redis集群是一个提供在多个Redis节点间共享数据的数据集Redis集群可以......
  • Docker部署Redis
    1、拉取redis镜像dockerpullredis2、创建redis配置文件mkdir-p/mydata/redis/conftouch/mydata/redis/conf/redis.conf3、启动redis镜像dockerrun-p6379:6379--nameredis\-v/mydata/redis/data:/data\-v/mydata/redis/conf/redis.conf:/etc/redis/redis.......
  • Redis远程字典服务
    1介绍Redis(RemoteDictionaryServer)是一个开源的内存数据存储系统,可以用作数据库、缓存和消息中间件。它支持多种数据结构,包括字符串(strings)、哈希表(hashes)、列表(lists)、集合(sets)、有序集合(sortedsets)等。2使用场景相对于使用数据库,它读取更方便,时间更短相对于存储在硬盘上,它可......
  • Django-redis 常见错误
    Django-redis是一个Django缓存模块,用于连接Redis数据库。在使用Django-redis异步操作时,可能会遇到一些常见的错误。以下是一些可能出现的错误及其解决方法:Redis连接错误:原因:无法连接到Redis数据库。解决方法:检查Redis数据库是否已启动,并确保在Django设置中正确配置了......
  • Redis集群
    1.描述集群,即是RedisCluster。其由多个redis节点组成,redis数据保存在这些节点中。这些节点分为主节点和从节点:只有主节点负责读写请求和集群信息的维护,从节点只负责主节点数据和状态的复制。2.作用数据分区:redis集群是将数据分散存到多个节点中的。具体存到哪个节点是根绝数......
  • # yyds干货盘点 # 盘点一个Python正则表达式的问题
    大家好,我是皮皮。一、前言前几天在Python最强王者交流群【崔艳飞】问了一个Python正则表达式的问题,一起来看看吧。问题如下:'/H/H_OMC*/Mo/20231128/share',各位大神,引号内的*通配符,咋让起作用?加个引号,不灵了。二、实现过程这里【哎呦喂 是豆子~】、【莫生气】给了一个指导,比方说加......
  • Redis基础命令操作
    一、基础命令1.ping(心跳检查)ping//输入ping命令,看到PONG响应,说明客户端与Redis的连接正常。 2.get/set(读写键值)setnamexiaoHong//setkeyvalue会将指定key-value写入到DB。getname//getkey则会读取指定key的value值。 3.select(切换数据库)sel......
  • docker部署redis主从集群
    1、创建数据目录(logs目录要给权限,要不然会报错)mkdir-pv/data/redis/(data,logs}chmod777/data/redis/logs2、redis.conf配置文件-—-主从配置master节点配置cd/data/redisvimredis.confport6379bind0.0.0.0daemonizenoprotected-modenorequirepass123......