redis中Key操作命令

本文详细介绍了Redis中Map数据结构以及常用的11个命令,如keys用于查找key,exists检查key存在性,del删除key等,强调了scan命令在生产环境中的优势。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

注:此文章为个人学习笔记,如有错误欢迎指出。
Redis中存储的数据整体是一个Map,其keyString类型,而value则可以是String
Hash表、ListSet等类型。
1 keys
格式:KEYS pattern
功能:查找所有符合给定模式 pattern keypattern 为正则表达式。
说明:KEYS 的速度非常快,但在一个大的数据库中使用它可能会阻塞当前服务器的服
务。所以生产环境中一般不使用该命令,而使用 scan 命令代替。
2 exists
格式:EXISTS key
功能:检查给定 key 是否存在。
说明:若 key 存在,返回 1 ,否则返回 0
3 del
格式:DEL key [key ...]
功能:删除给定的一个或多个 key 。不存在的 key 会被忽略。
说明:返回被删除 key 的数量。
4 rename
格式:RENAME key newkey
功能:将 key 改名为 newkey
说明:当 key 不存在时,返回一个错误。当 newkey 已经存在时, RENAME 命令将覆盖旧值。改名成功时提示 OK ,失败时候返回一个错误。
5 move
格式:MOVE key db
功能:将当前数据库的 key 移动到给定的数据库 db 当中。
说明:如果当前数据库(源数据库)和给定数据库(目标数据库)有相同名字的给定 key
或者 key 不存在于当前数据库,那么 MOVE 没有任何效果。移动成功返回 1 ,失败
则返回 0 。
6 type
格式:TYPE key
功能:返回 key 所储存的值的类型。
说明:返回值有以下六种
string (字符串)
list (列表)
set (集合)
zset (有序集)
hash (哈希表)
7 expire pexpire
格式:EXPIRE key seconds
功能:为给定 key 设置生存时间。当 key 过期时(生存时间为 0),它会被自动删除。
expire 的时间单位为秒,pexpire 的时间单位为毫秒。在 Redis 中,带有生存时间的 key
被称为易失的”(volatile)
说明:生存时间设置成功返回 1。若 key 不存在时返回 0 rename 操作不会改变 key
的生存时间。
8 ttl pttl
格式:TTL key
功能:TTL, time to live,返回给定 key 的剩余生存时间。
说明:其返回值存在三种可能:
key 不存在时,返回 -2
key 存在但没有设置剩余生存时间时,返回 -1
否则,返回 key 的剩余生存时间。ttl 命令返回的时间单位为秒,而 pttl 命令
返回的时间单位为毫秒。
9 persist
格式:PERSIST key
功能:去除给定 key 的生存时间,将这个 key 易失的转换成持久的
说明:当生存时间移除成功时,返回 1;若 key 不存在或 key 没有设置生存时间,则
返回 0
10 randomkey
格式:RANDOMKEY
功能:从当前数据库中随机返回(不删除)一个 key
说明:当数据库不为空时,返回一个 key。当数据库为空时,返回 nil。主要是用于判断数据库是否为空。
11 scan
格式:SCAN cursor [MATCH pattern] [COUNT count] [TYPE type]
功能:用于迭代数据库中的数据库键。其各个选项的意义为:
cursor:本次迭代开始的游标。
pattern :本次迭代要匹配的 key 的模式。
count :本次迭代要从数据集里返回多少元素,默认值为 10
type:本次迭代要返回的 value 的类型,默认为所有类型。
SCAN 命令是一个基于游标 cursor 的迭代器:SCAN 命令每次被调用之后,都会向用
户返回返回一个包含两个元素的数组, 第一个元素是用于进行下一次迭代的新游标,
而第二个元素则是一个数组, 这个数组中包含了所有被迭代的元素。用户在下次迭代
时需要使用这个新游标作为 SCAN 命令的游标参数,以此来延续之前的迭代过程。当
SCAN 命令的游标参数被设置为 0 时,服务器将开始一次新的迭代。如果新游标返回 0
表示迭代已结束。
说明:使用间断的、负数、超出范围或者其他非正常的游标来执行增量式迭代不会造成
服务器崩溃。
当数据量很大时,count 的数量的指定可能会不起作用,Redis 会自动调整每次的遍
历数目。由于 scan 命令每次执行都只会返回少量元素,所以该命令可以用于生产环境,
而不会出现像 KEYS 命令带来的服务器阻塞问题。
增量式迭代命令所使用的算法只保证在数据集的大小有界的情况下迭代才会停止,
换句话说,如果被迭代数据集的大小不断地增长的话,增量式迭代命令可能永远也无法
完成一次完整迭代。即当一个数据集不断地变大时,想要访问这个数据集中的所有元素
就需要做越来越多的工作, 能否结束一个迭代取决于用户执行迭代的速度是否比数据
集增长的速度更快。
相关命令:另外还有 3 scan 命令用于对三种类型的 value 进行遍历。
hscan:属于 Hash Value 操作命令集合,用于遍历当前 db 中指定 Hash 表的
所有 field-value 对。
sscan:属于 Set Value 操作命令集合,用于遍历当前 db 中指定 set 集合的所
有元素
zscan:属于 ZSet Value 操作命令集合,用于遍历当前 db 中指定有序集合的
所有元素(数值与元素值)
加入一个set类型的name
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值