redis数据类型之string,list

华子目录

  • key操作
    • 说明
      • `SCAN cursor [MATCH pattern] [COUNT count]`
      • `dump`与`restore`
      • `keys 通配符`
    • 示例演示
  • `string`
    • 说明
      • `setbit key offset value`
      • `getbit key offset`
      • `setrange key offset value`
  • `List`
    • 结构图
    • 相关命令
      • `lrem key count value`
      • `ltrim key count value`
      • 示例:使用 LTRIM 裁剪列表
      • `blpop key1 [key2...] timeout`
      • `brpoplpush source destination timeout`
      • 命令语法
      • 返回值
      • 特点与注意事项
      • 示例
      • `rpoplpush source destination`
      • 命令语法
      • 返回值
      • 示例
      • 应用场景
      • `lmove source destination left|right left|right`
      • 命令语法
      • 示例
      • 注意点
      • 返回值
      • 总结

key操作

命令说明
del key名key存在删除key
exists key名检查给定 key 是否存在,存在返回1,否则返回0
keys 通配符查找所有符合给定模式( pattern)的 key
move key名 dbid将当前数据库的 key 移动到给定的数据库 dbid当中
rename key名 新key名修改 key 的名称
renamex key名 新key名仅当newkey不存在时,将key改名为newkey
type key名返回 key 所储存的值的类型
select dbid切换数据库 ,数据库为0-15(默认一共16个数据库)
dbsize查看数据库的key数量
flushdb清空当前数据库中的数据
flushall清空所有数据库中的数据
echo打印命令
dump key名序列化给定 key ,并返回被序列化的值
expire key名 seconds为给定 key 设置过期时间,以秒计
expireat key名 timestampkey 设置过期时间,时间参数是 UNIX 时间戳
pexprieat key名 milliseconds-timestamp设置 key 过期时间的时间戳(unix timestamp) 毫秒计
persist key名移除 key 的过期时间,key持久保持
ttl key名为单位,返回给定 key剩余生存时间(TTL, time to live),如果 key 不存在或者没有设置过期时间,则返回 -1 或 -2。
pttl key名毫秒为单位返回 key 的剩余的过期时间
randomkey从当前数据库中随机返回一个 key
scan cursor [match pattern] [count count]迭代数据库中的数据库键

说明

SCAN cursor [MATCH pattern] [COUNT count]

  • SCAN cursor [MATCH pattern] [COUNT count] 是 Redis 数据库中的一个命令,用于迭代数据库中的键。这个命令特别有用,因为它允许你在不阻塞 Redis 服务器的情况下,以增量方式检索键。

这里是命令的各个部分的解释:

  1. SCAN cursor

    • cursor 是一个无符号的 64 位整数,用于迭代过程。在第一次调用 SCAN 时,应将其设置为 0。每次调用 SCAN 后,它都会返回一个新的 cursor 值,你可以在下一次调用时使用这个值来继续迭代。
    • cursor 返回 0 时,表示迭代已完成。
  2. [MATCH pattern]

    • 这是一个可选参数,允许你指定一个模式来过滤返回的键。模式使用 glob 风格的通配符,其中 ? 匹配一个字符,而 * 匹配零个或多个字符。
    • 例如,MATCH user:* 将只返回以 “user:” 开头的键。
  3. [COUNT count]

    • 这也是一个可选参数,它告诉 Redis 在每次迭代中尝试返回的键的数量。请注意,这是一个提示,而不是一个严格的限制。Redis 可能会返回更多的键,也可能会返回更少的键。
    • 使用 COUNT 可以帮助你更好地控制迭代的速度和资源的使用。例如,如果你希望迭代进行得慢一些以减少对 Redis 的压力,你可以设置一个较小的 count 值。

示例:

假设你有一个包含大量键的 Redis 数据库,并且你想迭代并打印出所有以 “user:” 开头的键。你可以使用如下的 Lua 脚本来完成这个任务(这里使用 Redis 的 Lua 脚本只是为了演示目的,实际上你可以直接在 Redis 命令行或客户端中调用 SCAN 命令):

local cursor = '0'
local pattern = 'user:*'
local count = 100repeatlocal res = redis.call('SCAN', cursor, 'MATCH', pattern, 'COUNT', count)cursor = res[1]local keys = res[2]for i, key in ipairs(keys) doprint(key)end
until cursor == '0'

这个脚本会不断调用 SCAN 命令,直到迭代完成(即 cursor 变为 0)。在每次迭代中,它都会打印出返回的键。

dumprestore

  • 在 Redis 中,DUMP 命令用于序列化给定的键(key),并返回一个包含键值的序列化版本的二进制字符串。这个命令对于迁移或备份特定键的值非常有用。

DUMP 命令的语法如下:

DUMP key

其中 key 是你想要序列化的键的名称。

如果键存在,DUMP 命令将返回一个包含两个元素的字符串数组:

  1. 第一个元素是一个字符串,表示该键值的序列化版本。
  2. 第二个元素是一个整数,表示该键值的 RDB 版本(Redis Database version)。在大多数情况下,这个值可以被忽略,除非你在处理 RDB 格式的 Redis 快照。

例如,假设你在 Redis 中设置了一个键值对,并且键为 “mykey”,值为 “Hello, Redis!”,你可以使用 DUMP 命令来序列化这个键的值:

redis-cli DUMP mykey

输出可能类似于:

"\x00\x0dHello, Redis!\r\n"

注意这个输出是一个二进制字符串,并且可能包含不可见的字符(如换行符)。这个序列化字符串可以使用 RESTORE 命令在另一个 Redis 数据库中恢复为原始键值对。

RESTORE 命令的语法如下:

RESTORE key ttl serialized-value [REPLACE] [ABSTTL] [IDLETIME idle-time] [FREQ freq]

其中:

  • key 是要恢复的键的名称。
  • ttl 是该键的过期时间(以秒为单位),如果设置为 0,则键永不过期。
  • serialized-valueDUMP 命令返回的序列化值。
  • [REPLACE] 是一个可选参数,如果键已经存在并且设置了该参数,则替换旧值。
  • [ABSTTL] 是一个可选参数,如果设置,则 ttl 是绝对时间戳(以 UNIX 时间戳表示)。
  • [IDLETIME idle-time] 是一个可选参数,用于设置键的空闲时间。
  • [FREQ freq] 是一个可选参数,用于设置访问频率(仅在 Redis 6.0 及更高版本中可用)。

请注意,DUMPRESTORE 命令通常用于高级用例,如跨 Redis 实例迁移数据。对于常规的数据备份和恢复操作,你可能需要使用其他方法,如 Redis 的持久化功能(RDB 快照或 AOF 日志)或 Redis 的复制和集群功能。

keys 通配符

  • keys * 匹配数据库中所有key
  • keys h?llo 匹配hello,hallo,hxllo等key
  • keys h*llo 匹配hllo,heeello等key
  • keys h[ae]llo 匹配hello,hallo

示例演示

[root@server ~]# redis-cli -p 6379   #-p指定端口号
127.0.0.1:6379> dbsize
(integer) 0
127.0.0.1:6379> set name huazi
OK
127.0.0.1:6379> dbsize
(integer) 1
127.0.0.1:6379> get name
"huazi"
127.0.0.1:6379> del name
(integer) 1
127.0.0.1:6379> dbsize
(integer) 0
127.0.0.1:6379> get name
(nil)
127.0.0.1:6379> select 1
OK
127.0.0.1:6379[1]> set name huazi
OK
127.0.0.1:6379[1]> move name 0
(integer) 1
127.0.0.1:6379[1]> select 0
OK
127.0.0.1:6379> dbsize
(integer) 1
127.0.0.1:6379> get name
"huazi"
127.0.0.1:6379> keys na*
1) "name"
127.0.0.1:6379> exists name     #存在返回1,
(integer) 1
127.0.0.1:6379> exists name1    #不存在返回0
(integer) 0
127.0.0.1:6379> expire name 10    #设置10s期限
(integer) 1
127.0.0.1:6379> get name   #10s内可以得到key值
"huazi"
127.0.0.1:6379> get name    #10s过后key值被销毁
(nil)
127.0.0.1:6379> set name huazi
OK
127.0.0.1:6379> rename name key
OK
127.0.0.1:6379> get key
"huazi"
127.0.0.1:6379> expire key 30    #设置过期时间为30s
(integer) 1
127.0.0.1:6379> ttl key    #查看剩余时间
(integer) 27
127.0.0.1:6379> persist key   #将key的时间设置为永久
(integer) 1
127.0.0.1:6379> ttl key
(integer) -1127.0.0.1:6379> set name huazi
OK
127.0.0.1:6379> flushdb   #删除当前数据库中的数据
OK
127.0.0.1:6379> keys *
(empty array)
127.0.0.1:6379> select 1   #切换到1数据库
OK
127.0.0.1:6379[1]> keys *
1) "name"
127.0.0.1:6379[1]> select 0   #切换到0数据库
OK
127.0.0.1:6379> flushall   #删除所有数据库中的数据
OK
127.0.0.1:6379> select 1
OK
127.0.0.1:6379[1]> keys *
(empty array)
127.0.0.1:6379[1]> select 0
OK
127.0.0.1:6379[1]> set name huazi
OK
127.0.0.1:6379[1]> move name 0   #将key为name的键值对移动到0数据库,移动后就没有这个键值对了
(integer) 1
127.0.0.1:6379[1]> keys *
(empty array)

string

  • Stringredis 最基本的类型,你可以理解成与 Memcached 一模一样的类型,一个 key 对应一个 value
  • String 类型是二进制安全的意思是 redisstring 可以包含任何数据。比如jpg图片或者序列化的对象。
  • String 类型是 Redis 最基本的数据类型,String类型的值最大能存储 512MB。
  • String类型一般用于缓存、限流、计数器、分布式锁、分布式Session。
命令说明
set key value设置指定 key 的值
get key获取指定 key 的值
getrange key start end返回 key 中字符串值的子字符end=-1时表示全部
setbit key offset valuekey 所储存的字符串值,设置或清除指定偏移量上的位(bit)
getbit key offsetkey 所储存的字符串值,获取指定偏移量上的位(bit)
mset key value [key value...]同时设置一个或多个 key-value
mget key1 [key2...]获取所有(一个或多个)给定 key 的值
getset key value将给定 key 的值设为 value ,并返回 key的旧值(old value)
setex key seconds value设置key的值value ,并将 key 的过期时间设为 seconds (以为单位)
setnx key value只有在 key 不存在时设置 key 的值
setrange key offset valuevalue 参数覆盖给定 key 所储存的字符串值,从偏移量 offset 开始,默认从下标0开始
strlen key返回 key 所储存的字符串值的长度
msetnx key value [key value...]同时设置一个或多个 key-value 对,当且仅当所有给定 key不存在
psetex key milliseconds valuesetex 命令相似,但它以毫秒为单位设置 key 的生存时间
incr keykey 中储存的数字值增一
incrby key incrementkey 所储存的值加上给定的增量值(increment)
incrbyfloat key incrementkey 所储存的值加上给定的浮点增量值(increment)
decr keykey 中储存的数字值减一
decrby key decrementkey 所储存的值减去给定的减量值(decrement)
append key value如果 key 已经存在并且是一个字符串,append 命令将指定的 value 追加到该 key 原来值 value末尾

说明

setbit key offset value

  • Redis 中,SETBIT 命令用于设置字符串值(string value)在指定偏移量(offset)上的位(bit)的值。这个命令在二进制数据处理中非常有用,特别是当你需要以单位存储或修改数据时。

SETBIT 命令的语法如下:

SETBIT key offset value
  • key 是你想要操作的键的名称。
  • offset 是你想要设置的位的偏移量(从 0 开始计数)。
  • value 是你想要设置的位的值,只能是 0 或 1。

如果 key 不存在,Redis 会创建一个新的字符串值,并且这个字符串值的长度足以容纳指定的偏移量。在偏移量之后的字符串部分会被填充为 0(即空的二进制字符串)。

如果 offset 大于当前字符串值的长度,Redis 会在字符串的末尾添加足够的 0 来达到指定的偏移量,然后设置该位的值。

需要注意的是,SETBIT 命令并不会自动扩展字符串的长度以包含整个字节(8位)。如果你设置了一个字符串末尾之后的位,Redis 只会扩展字符串到足以包含该位的长度,而不会扩展到下一个完整的字节。

示例:

  • 假设你有一个名为 mykey 的键,并且它的值是字符串 "a"(在 ASCII 中,'a' 的值是 97,其二进制表示为 01100001)。现在你想要设置第 7 位的值为 1(从右往左数,最低位是第 0 位):
redis-cli SETBIT mykey 7 1

这个命令将把 mykey 的值修改为二进制表示 01100011,对应的 ASCII 字符是 'c'。所以,如果你之后使用 GET mykey 命令,你将得到值 "c"

注意:虽然 SETBIT 命令可以修改字符串中的位,但修改后的字符串可能不再是一个有效的文本字符串(即它可能不再表示一个可打印的字符或字符串)。在上面的示例中,我们修改了 'a' 的二进制表示来得到一个不同的字符 'c'。但是,你也可以使用 SETBIT 命令来修改任意二进制数据,而不仅仅是可打印的字符串。

getbit key offset

  • 在 Redis 中,GETBIT 命令用于获取字符串值(string value)在指定偏移量(offset)上的位的值。这个命令在处理二进制数据时非常有用,因为它允许你以位为单位读取数据。

GETBIT 命令的语法如下:

GETBIT key offset
  • key 是你想要获取其位值的键的名称。
  • offset 是你想要获取的位的偏移量(从 0 开始计数)。

如果 key 不存在,或者 offset 超出了字符串值的长度,GETBIT 命令将返回 0

示例:

假设你有一个名为 mykey 的键,并且它的值是字符串 "a"(在 ASCII 中,'a' 的值是 97,其二进制表示为 01100001)。现在你想要获取第 2 位的值(从右往左数,最低位是第 0 位):

redis-cli GETBIT mykey 2

这个命令将返回 1,因为第 2 位(从右往左数)在二进制表示 01100001 中是 1

如果你尝试获取一个不存在的键的位值,或者一个存在的键但偏移量超出了其值的长度,GETBIT 命令将返回 0

redis-cli GETBIT nonexistingkey 0  # 返回 0,因为键不存在
redis-cli SET mykey "a"
redis-cli GETBIT mykey 7  # 返回 0,因为 "a" 的二进制表示只有 7 位,第 7 位不存在

请注意,偏移量是从 0 开始的,并且 Redis 允许你访问字符串值末尾之后的位(即超出当前字符串长度的偏移量),但这些位的值将被视为 0

setrange key offset value

SETRANGE 命令在 Redis 中的用法

SETRANGE 是 Redis 中的一个命令,用于在指定的 key 所储存的字符串值中,从偏移量 offset 开始,用指定的字符串 value 覆盖。以下是关于 SETRANGE 命令的详细解释:

  1. 基本语法

    SETRANGE key offset value
    
    • key:需要修改的字符串键名。
    • offset:开始覆盖的偏移量。
    • value:要覆盖的字符串值。
  2. 返回值
    命令执行后,返回被修改后的字符串总长度。

  3. 注意事项

    • 如果 key 原来储存的字符串长度比 offset 小,那么在原字符串offset 之间的空白部分将用零字节(“\x00”)来填充。
    • 最大偏移量是 2^29-1(即 536,870,911),因为 Redis 字符串的大小被限制在 512 兆以内。如果需要更大的空间,可以使用多个 key 来实现。
    • 当生成一个很长的字符串时,Redis 需要分配内存空间,这有时候可能会造成服务器阻塞。
  4. 命令示例

    • 假设当前 key “url” 的值为 “this site”:
      127.0.0.1:6379> SET url "this site"
      OK
      127.0.0.1:6379> SETRANGE url 5 www.biancheng.net
      (integer) 22
      127.0.0.1:6379> GET url
      "this www.biancheng.net"
      
    • 这里,我们从偏移量 5 开始,用 "www.biancheng.net" 覆盖了原来的字符串。
  5. 内存分配

    • 当首次为 key 分配内存空间时,Redis 会根据需要分配足够的内存来存储字符串。如果之后再次对该 key 使用 SETRANGE 命令,并且新的字符串长度没有超过已分配的内存大小,Redis 则不会重新分配内存。
  6. 版本要求

    • SETRANGE 命令在 Redis 2.2.0 及之后的版本中可用。

综上所述,SETRANGE 命令为 Redis 提供了一个在字符串中指定位置进行覆盖的功能,使得对字符串的修改操作更加灵活和高效。

List

  • Redis列表是简单的字符串列表,按照插入顺序排序。你可以添加一个元素到列表的头部(左边)或者尾部(右边)一个列表最多可以包含2^32^ - 1个元素 (4294967295, 每个列表超过40亿个元素)。
  • List类型一般用于关注人、简单队列

结构图

在这里插入图片描述

相关命令

命令语法说明
lpush key value1 [value2...]一个多个值插入到列表头部
lpop key移出获取列表的第一个元素
lrange key start stop获取列表指定范围内的元素
lpushx key value一个值插入到已存在列表头部
rpush key value1 [value2...]列表中添加一个多个值
rpop key移除列表的最后一个元素返回值为移除的元素
rpushx key value为已存在的列表添加值
llen key获取列表长度
linsert key before | after pivot value在列表的pivot元素前或者后插入value元素
lindex key index通过索引获取列表中的元素
lset key index value通过索引修改列表元素的
lrem key count value移除列表元素
ltrim key count value对一个列表进行修剪,就是让列表只保留指定区间内的元素不在指定区间之内的元素都将被删除
blpop key1 [key2...] timeout移出并获取列表的第一个元素,如果列表没有元素会阻塞列表直到等待超时或发现可弹出元素为止 block left pop (两个会话测试)
brpop key1 [key2...] timeout移出并获取列表的最后一个元素,如果列表没有元素会阻塞列表直到等待超时或发现可弹出元素为止
brpoplpush source destination timeout从列表中弹出一个值,将弹出的元素插入到另外一个列表中并返回它;如果列表没有元素会阻塞列表直到等待超时或发现可弹出元素为止
rpoplpush source destination移除列表的最后一个元素,并将该元素添加到另一个列表并返回
lmove source destination right leftsource的右边的值移动到destination左边插入
lmpop numkeys key1 [key2...] left|right count给定多个列表key1 key2 判断key1是否为空,不为空弹出该key的元素,为空直到找到不为空的key弹出对应的元素。

lrem key count value

LREM 是 Redis 中的一个命令,用于从列表中移除指定数量的、与指定值相等的元素。以下是关于 LREM 命令的详细说明:

命令语法

lrem key count value
  • key:列表的键名。
  • count:要移除的元素数量。这个参数有几个可能的值:
    • 如果 count > 0,则从头向尾搜索并移除等于 value 的元素,直到移除了 count 个。
    • 如果 count < 0,则从尾向头搜索并移除等于 value 的元素,直到移除了 abs(count) 个。
    • 如果 count = 0,则移除列表中所有等于 value 的元素。
  • value:要移除的元素的值。

返回值

  • 命令执行后被移除的元素数量。

ltrim key count value

  • 实际上,ltrim 命令在 Redis 中并不是通过 key count value 这样的参数来使用的。LTRIM 命令用于对列表进行裁剪,保留指定范围内的元素,而不需要指定一个具体的值。

命令语法

LTRIM key start stop
  • key:列表的键名。
  • startstop:要保留的元素的索引范围。索引从 0 开始。例如,0 表示列表的第一个元素,-1 表示列表的最后一个元素,-2 表示倒数第二个元素,依此类推。

示例

假设我们有一个名为 mylist 的 Redis 列表,它包含以下元素:

redis-cli RPUSH mylist 1 2 3 4 5

此时,mylist 的内容为 [1, 2, 3, 4, 5]

示例:使用 LTRIM 裁剪列表

如果我们想要保留索引从 13(包含)的元素(即 [2, 3, 4]),我们可以这样做:

redis-cli LTRIM mylist 1 3

执行后,mylist 的内容将变为 [2, 3, 4]

请注意,如果 start 的值大于列表的实际长度,或者 start 大于 stop,则列表将被清空。

例如,如果我们执行以下命令:

redis-cli LTRIM mylist 10 15

由于列表 mylist 只有 5 个元素,索引从 04,所以执行上述命令后,mylist 将被清空。

另外,如果你之前提到的 lrem key count value 是一个误解或笔误,请忽略,因为我已经在之前的回答中解释了 LREM 命令的用法。

blpop key1 [key2...] timeout

  • BLPOPRedis 中的一个命令,用于从列表的左侧移除并获取一个或多个列表中的第一个元素,如果列表为空,则阻塞等待直到有元素可获取或者超过指定的超时时间。

命令语法

blpop key1 [key2 ...] timeout
  • key1 [key2 ...]:一个或多个列表的键名。BLPOP 会按照给定的 key 顺序检查列表,并在找到第一个非空列表时从中弹出一个元素。
  • timeout:阻塞等待的时间(以秒为单位),或者为 0 表示永远阻塞。

返回值

  • 如果在 timeout 秒内找到了一个非空列表并成功弹出元素,则返回包含两个元素的列表:第一个元素是被弹出元素的列表名,第二个元素是被弹出的元素值。
  • 如果在 timeout 秒内没有找到任何非空列表,则返回 nil

示例

假设我们有两个列表 list1list2,它们的内容分别为:

redis-cli RPUSH list1 a b c
redis-cli RPUSH list2 x y z

此时,list1 的内容为 [a, b, c]list2 的内容为 [x, y, z]

如果我们执行以下命令:

redis-cli BLPOP list1 list2 5

因为 list1 是非空的,所以 BLPOP 会立即返回 list1 的第一个元素 a,并同时从 list1 中移除该元素。返回的结果将是:

1) "list1"
2) "a"

如果我们再次执行相同的命令(此时 list1 的内容为 [b, c]),BLPOP 仍然会立即返回 list1 的第一个元素 b

但是,如果我们清空 list1list2,并尝试执行以下命令:

redis-cli BLPOP list1 list2 5

由于两个列表都是空的,BLPOP 会阻塞等待,直到有元素被添加到其中一个列表,或者超过 5 秒的超时时间。如果 5 秒内没有任何变化,则返回 nil

BLPOP 常用于实现队列(queue)或任务列表(task list)等需要按照顺序处理元素的应用场景。

brpoplpush source destination timeout

BRPOPLPUSH 是 Redis 中的一个命令,它是 RPOPLPUSH 的阻塞版本。这个命令主要用于从一个列表(source)的尾部弹出一个元素,并将其推送到另一个列表(destination)的头部。如果 source 列表为空,Redis 会阻塞这个连接,直到另一个客户端 push 元素进入 source 列表,或者达到指定的超时时间(timeout)。

以下是关于 BRPOPLPUSH 命令的详细解释:

命令语法

BRPOPLPUSH source destination timeout
  • source:要弹出最后一个元素的列表的键名。
  • destination:要将弹出的元素插入的列表的键名。
  • timeout:超时时间(以秒为单位)。设置为 0 表示无限期阻塞。

返回值

  • 如果在超时时间内 source 列表中有元素被弹出,命令将返回被弹出元素的值。
  • 如果在超时时间内没有任何元素被弹出,命令将返回一个 nil 和等待时长(以秒为单位)。

特点与注意事项

  • 如果 source 列表在调用命令时不存在或为空,Redis 会阻塞客户端连接,直到 source 列表中有元素可用或超时。
  • 如果 sourcedestination 是同一个列表,这个命令可以看作是列表的翻转操作,将尾部元素移动到头部。
  • timeout 参数允许你指定一个最大等待时间。如果在这个时间内没有元素被弹出,命令将返回 nil 和等待时长。
  • BRPOPLPUSH 命令的时间复杂度为 O(1),因为它只涉及常数时间的操作。

示例

假设我们有两个列表 list1list2,其中 list1 为空,list2 包含一些元素。如果我们执行以下命令:

redis-cli BRPOPLPUSH list1 list2 10

Redis 会阻塞这个连接,等待 list1 中有元素被 push,或者等待 10 秒超时。因为 list1 为空且没有新元素被 push 进去,所以这个命令在 10 秒后将返回一个 nil 和等待时长 10.xx 秒。

如果我们在另一个客户端中向 list1 push 一个元素,比如 a,那么上述被阻塞的 BRPOPLPUSH 命令会立即返回,并将 a 插入到 list2 的头部,同时从 list1 中移除 a。返回的值将是 a

rpoplpush source destination

  • RPOPLPUSHRedis 中的一个命令,它从一个列表(source)的尾部移除并获取一个元素,然后将这个元素推送到另一个列表(destination)的头部。这个命令是一个原子操作,即它在执行过程中不会被其他命令打断。

命令语法

RPOPLPUSH source destination
  • source:要弹出最后一个元素的列表的键名。
  • destination:要将弹出的元素插入的列表的键名。

返回值

  • 如果 source 列表不为空,命令将返回被弹出元素的值。
  • 如果 source 列表为空,命令将返回 nil

示例

假设我们有两个列表 list1list2,其中 list1 包含一些元素,而 list2 为空或包含其他元素。如果我们执行以下命令:

redis-cli RPOPLPUSH list1 list2

Redis 会从 list1 的尾部弹出一个元素,并将其推送到 list2 的头部。如果 list1 不为空,这个命令将返回被弹出元素的值;如果 list1 为空,这个命令将返回 nil

应用场景

RPOPLPUSH 命令通常用于实现消息队列或任务队列的场景。例如,你可以将待处理的任务推送到一个列表(例如 tasks),并使用多个工作进程或线程来消费这些任务。每个工作进程或线程可以使用 BRPOPLPUSH(阻塞版本的 RPOPLPUSH)或 RPOPLPUSH 来从 tasks 列表中获取任务,并在处理完任务后将结果推送到另一个列表(例如 results)。这样可以确保任务的处理是顺序的,并且可以在多个工作进程或线程之间平衡负载。

lmove source destination left|right left|right

LMOVERedis 中的一个命令,用于从一个列表(source)中移除一个元素,并将其推送到另一个列表(destination)中。该命令允许指定元素是从列表的左侧还是右侧移除,并指定推送到目标列表的左侧还是右侧。

命令语法

LMOVE source destination LEFT|RIGHT LEFT|RIGHT
  • source:源列表的键名。
  • destination:目标列表的键名。
  • 第一个 LEFT|RIGHT:指定从源列表中移除元素的位置(LEFT 表示左侧,RIGHT 表示右侧)。
  • 第二个 LEFT|RIGHT:指定将元素推送到目标列表的位置(LEFT 表示左侧,RIGHT 表示右侧)。

示例

假设我们有以下两个列表:

  • source 列表成员为:a, b, c
  • destination 列表成员为:x, y, z

如果我们执行以下命令:

redis-cli LMOVE source destination RIGHT LEFT

那么执行后的结果将是:

  • source 列表成员变为:a, b
  • destination 列表成员变为:c, x, y, z

在这个例子中,我们从 source 列表的右侧(RIGHT)移除了元素 c,并将其推送到了 destination 列表的左侧(LEFT)。

注意点

  • 如果 source 列表不存在,LMOVE 命令将返回 nil 并且不会执行任何操作。
  • 如果 sourcedestination 列表相同,并且指定的移除和推送位置也相同(例如 LMOVE mylist mylist RIGHT RIGHT),则这个命令相当于在列表内部移动元素,即实现列表的循环。
  • 如果 source 列表为空,则 LMOVE 命令同样会返回 nil 并且不会执行任何操作。

返回值

  • 如果命令成功执行,则返回被移除并推送到目标列表的元素值。
  • 如果命令未执行任何操作(例如,因为源列表不存在或为空),则返回 nil

总结

LMOVE 命令提供了在 Redis 中从一个列表移除元素并将其推送到另一个列表的功能,同时允许指定移除和推送的位置。这使得在处理列表数据时具有更大的灵活性。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/18330.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Octo:伯克利开源机器人开发框架

【摘要】在各种机器人数据集上预先训练的大型策略有可能改变机器人学习&#xff1a;这种通用机器人策略无需从头开始训练新策略&#xff0c;只需使用少量领域内数据即可进行微调&#xff0c;但具有广泛的泛化能力。然而&#xff0c;为了广泛应用于各种机器人学习场景、环境和任…

IC618 虚拟机 EDA Calibre2019 Hspice2018 Spectre19.1

虚拟机包含 CentOS 7.9 Cadence IC618 Calibre 2019 Hspice 2018 Spectre19.1 下载地址&#xff1a; 链接&#xff1a;https://pan.baidu.com/s/1aMtPO2G5ad-x5BtIJjCDig?pwdxcii 提取码&#xff1a;xcii

闹掰了? 传Google Pixel 10芯片转单了 | 百能云芯

根据最新消息&#xff0c;Google Tensor G5处理器可能将选择台积电作为其新的生产伙伴&#xff0c;并计划在2025年的Pixel 10系列手机上亮相。这一消息由Android Authority率先报道&#xff0c;引起了业界的广泛关注。 据悉&#xff0c;自从2021年Google推出自研的Tensor处理器…

14.微信小程序之地理定位功能

目录 1.地理定位介绍 1.1 申请开通 1.2 使用方法 2.拒绝授权后的解决方案 3.开通腾讯位置服务 4.LBS 逆地址解析 1.地理定位介绍 小程序地理定位是指通过小程序开发平台提供的 API&#xff0c;来获取用户的地理位置信息。用户在使用小程序时&#xff0c;可以授权小程序获…

【前端常见面试题整理】

开放性的题目 自我介绍 突出学习能力 我想换工作的主要原因是 介绍项目 平时是如何学习前端开发的 主要就是两个途径&#xff0c;一个是查阅官方文档&#xff0c;然后就是在网上查找技术资料或者视频去学习。平时没事的时候也会看看github&#xff0c;同时关注一些社区和IT网…

医疗小程序源码SpringBoot2.X + Vue + UniAPP全栈开发

源码说明&#xff1a; 看到好多坛友都在求SpringBoot2.X Vue UniAPP&#xff0c;全栈开发医疗小程序 – 带源码课件&#xff0c;我看了一下&#xff0c;要么链接过期&#xff0c;要么课件有压缩密码。 特意整理了一份分享给大家&#xff0c;个人认为还是比较全面的。 希望…

【数据结构】-- 栈

栈 引入&#xff1a; 一种特殊的线性表&#xff0c;其只允许在固定的一端进行插入和删除元素操作。 进行数据插入和删除操作的一端 称为栈顶&#xff0c;另一端称为栈底。栈中的元素遵循先进后出的原则&#xff0c;先入栈的元素总是先后出栈。 压栈&#xff1a;栈的插入操作叫…

04--SpringBoot热部署与日志

1、热部署 1.1 引言 为了进一步提高开发效率&#xff0c;SpringBoot为我们提供了全部项目热部署&#xff0c;日后在开发过程中修改了部分代码或者相关配置文件之后&#xff0c;不需要再重启服务使其生效。在项目中开启了全局热部署之后&#xff0c;只需要在修改之后等待几秒钟…

广东省保健食品行业协会批复成为“世界酒中国菜”活动指导单位

广东省保健食品行业协会正式批复成为“世界酒中国菜”系列活动指导单位&#xff0c;共促餐饮文化交流发展 近日&#xff0c;广东省保健食品行业协会正式批复荐酒师国际认证&#xff08;广州&#xff09;有限公司&#xff0c;成为备受瞩目的“世界酒中国菜”系列活动的指导单位…

填补领域空白!TerDiT:首次探索大规模DiT模型量化问题(MMLab出品)

论文链接&#xff1a;https://arxiv.org/pdf/2405.14854 项目链接&#xff1a;https://github.com/Lucky-Lance/TerDiT 最近在大规模预训练的文本到图像扩散模型方面的发展显著提高了高保真图像的生成能力&#xff0c;特别是基于transformer架构的扩散模型&#xff08;DiTs&a…

奈飞CEO最新访谈:抢走你饭碗的不是AI,而是能熟练使用AI的人

大家好&#xff0c;我是木易&#xff0c;一个持续关注AI领域的互联网技术产品经理&#xff0c;国内Top2本科&#xff0c;美国Top10 CS研究生&#xff0c;MBA。我坚信AI是普通人变强的“外挂”&#xff0c;所以创建了“AI信息Gap”这个公众号&#xff0c;专注于分享AI全维度知识…

新书推荐:7.5 goto、break、continue语句

本节必须掌握的知识点&#xff1a; 示例二十六 代码分析 汇编解析 示例二十七 代码分析 汇编解析 7.5.1 示例二十六 ■goto语句&#xff1a;无条件转移语句。 语法格式&#xff1a; goto label; label : 代码; ●语法解析&#xff1a; 执行到goto语句时&#xff0c;则无…

Jetpack架构组件_1.基本知识

1.什么是Jetpack&#xff1f; Jetpack 是一个由多个库组成的套件&#xff0c;可帮助开发者遵循最佳做法、减少样板代码并编写可在各种 Android 版本和设备中一致运行的代码&#xff0c;让开发者可将精力集中于真正重要的编码工作。Jetpack 包含一系列 Android 库&#xff0c;它…

pcdn服务器应该怎么配?

要配置PCDN&#xff08;Private Content Delivery Network&#xff09;服务器&#xff0c;可以按照以下步骤进行&#xff1a; 需求分析&#xff1a;明确业务需求&#xff0c;确定所需的CDN功能和性能参数。这包括预期的流量、负载、内容类型、目标用户群体等。 硬件选择&#…

VCRUNTIME140_1.dll丢失是怎么回事?vcruntime140_1.dll无法继续执行代码的处理方法

VCRUNTIME140_1.dll丢失是怎么回事&#xff1f;问出这样的问题的人&#xff0c;一般是遇到vcruntime140_1.dll无法继续执行代码的问题了&#xff0c;找不到VCRUNTIME140_1.dll文件&#xff0c;那么程序就肯定是启动不了的&#xff0c;程序的启动是需要VCRUNTIME140_1.dll文件的…

Java进阶学习笔记1——课程介绍

课程适合学习的人员&#xff1a; 1&#xff09;具备一定java基础的人员&#xff1b; 2&#xff09;想深刻体会Java编程思想&#xff0c;成为大牛的人员&#xff1b; 学完有什么收获&#xff1f; 1&#xff09;掌握完整的Java基础技术体系&#xff1b; 2&#xff09;极强的编…

行为设计模式之状态模式

文章目录 概述定义结构图 2.代码示例小结 概述 定义 状态模式(state pattern)的定义: 允许一个对象在其内部状态改变时改变它的行为。 对象看起来似乎修改了它的类。 状态模式就是用于解决系统中复杂对象的状态转换以及不同状态下行为的封装问题.。状态模式将一个对象的状态…

New Phytologist:杨树特有miRNA在调控杨树抗旱中的分子机制

2024年3月6日&#xff0c;林木遗传育种全国重点实验室、北京林业大学生物科学与技术学院尹伟伦与夏新莉教授课题组在New Phytologist&#xff08;中科院一区&#xff0c;影响因子9.4&#xff09;期刊发表了题为“The miR6445-NAC029 module regulates drought tolerance by reg…

selenium 学习笔记(一)

pip的安装 新建一个txt curl https://bootstrap.pypa.io/get-pip.py -o get-pip.py 把上面的代码复制进去后&#xff0c;把后缀名改为.bat然后双击运行 当前目录会出现一个这个文件 然后在命令行pyhon get-pip.py等它下好就可以了selenium安装 需要安装到工程目…

云计算-Lambda事件 (Lambda Events)

检索事件信息 (Retrieving Event Information) 在上一个主题中&#xff0c;我们已经看到了如何创建一个Lambda函数、添加handler、添加触发器和配置执行策略。在本主题中&#xff0c;我们将对其进行扩展。到目前为止&#xff0c;我们看到的handler应用非常简单&#xff0c;但我…