«

Redis批量删除key的命令怎么使用

时间:2024-7-25 09:07     作者:韩俊     分类: Mysql


这篇文章主要介绍了Redis批量删除key的命令怎么使用的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Redis批量删除key的命令怎么使用文章都会有所收获,下面我们一起来看看吧。

redis中没有直接根据正则表达式删除key的命令,只有del key1 key2...命令

但是redis中有通过正则表达式获取key的命令:keys "正则表达式"

可以借助于xargs命令实现批量删除key,把查出来的key值当做参数传给del

redis-cli keys "mailspec*" | xargs del

完整命令:

[root@localhost redis7001]# redis-cli -h 192.169.1.71 -p 7001 -a 123456 keys em* | xargs -r -t -n1 ./redis-cli -h 192.169.1.71 -p 7001 -a 123456 del

    补充1:xargs命令后需加上参数-r,不然当keys的数量为0时,就会报错 (error) ERR wrong number of arguments for ‘del’ command

    补充2:xargs命令后需加上参数-n1,不然当集群情况keys的数量大于1时,可能会报错 (error) CROSSSLOT Keys in request don’t hash to the same slot

    补充3:不加-t也可以,加上-t会输出每次删除的内容,不加则不输出删除的内容,但还是会输出每次删除的key的数量

扩展:redis中批量删除key

1、删除所有的key,可以使用redis自身的命令:

flushdb 删除当前数据库中的所有Key

flushall 删除所有数据库中的key

2、使用linux中的xargs来删除所有的key

redis-cli keys “*” | xargs redis-cli del

3、删除包含有某些关键字的key

redis-cli keys “xxx*” | xargs redis-cli del

4、如果需要指定密码,可以这样使用:

redis-cli -a pwd keys “*” | xargs redis-cli -a pwd del

标签: mysql redis

热门推荐