本文摘自PHP中文网,作者尚,侵删。
redis实现批量删除:
1、访问redis根目录 cd /usr/local/redis-2.8.19
2、登录redis:redis-cli -h 127.0.0.1 -p 6379 (其中,127.0.0.1可以写成服务器的IP地址,6379为端口号)
3、查看所有key值:keys *
4、删除指定索引的值:del key
5、清空整个 Redis 服务器的数据:flushall
6、清空当前库中的所有 key:flushdb
【第一种方式】:
下面是批量删除以“key_”开头的所有redis数据 数量为100个
1 2 3 | redis-cli -h (IP地址) -p 6379 (端口号:6379) KEYS key_* | xargs redis-cli (-h (IP地址) -p 6379 (端口号:6379)) del
=>[执行后返回的结果影响数量]:(integer) 100[数量100个]
|
【上述命令中 DEL函数的具体用法】:
DEL key [key ...]
删除给定的一个或多个 key 。
不存在的 key 会被忽略。
时间复杂度:
O(N), N 为被删除的 key 的数量。
删除单个字符串类型的 key ,时间复杂度为O(1)。
删除单个列表、集合、有序集合或哈希表类型的 key ,时间复杂度为O(M), M 为以上数据结构内的元素数量。
返回值:
被删除 key 的数量。
【举例说明】:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 | # 删除单个 key
redis> SET name huangz
OK
redis> DEL name
(integer) 1
# 删除一个不存在的 key
redis> EXISTS phone
(integer) 0
redis> DEL phone # 失败,没有 key 被删除
(integer) 0
# 同时删除多个 key
redis> SET name "redis"
OK
redis> SET type "key-value store"
OK
redis> SET website "redis.com"
OK
redis> DEL name type website
(integer) 3
|
【第二种方式】:
第一种方式弊端:这样一个坏处每次都要建立一个连接,量小的话还可以接受,量大的话,效率不行。
通过内置的 Lua 解释器,可以使用 EVAL 命令对 Lua 脚本:
1 | redis-cli -h(IP地址) -p 6379(端口号:6379) -- EVAL "return redis.call('del', unpack(redis.call('keys', ARGV[1])))" 0 'Volume:*'
|
【注】:但这种处理方式,量大的情况下,lua函数unpack会出现问题,会报错误
1 2 3 | '' '
(error) ERR Error running script (call to f_e177a091510d969af3b388ee986dbe6658df6b57): @user_script:1: user_script:1: too many results to unpack
'' '
|
【第二种方式优化后】:
【注释】:首先定义一个数组 keys,里面存储了模式匹配的所有的以 ‘Volume:’的key,然后for循环,每次处理5000个key,也就是说每次del 5000个key
1 2 3 4 5 6 | redis-cli -h(IP地址) -p 6379(端口号:6379) -- EVAL "local keys = redis.call( 'keys' , ARGV[1])
for i=1,#keys,5000
do
redis.call( 'del' , unpack(keys, i, math.min(i+4999, #keys)))
end
return #keys" 0 'Volume:*'
|
【第二种方式弊端】:
阅读剩余部分
相关阅读 >>
总结分享一些关于Redis缓存的面试题
linux如何启动Redis
Redis是否线程安全
Redis怎么做mysql缓存
Redis添加systemctl服务的具体步骤
mysql使用命令实现分级查找帮助的方法
Redis数据淘汰策略是什么
查看Redis是否持久化
Redis怎么清缓存
Redis为什么那么快
更多相关阅读请进入《Redis》频道 >>
机械工业出版社
本书主要讲述了数据模型、基于对象的数据库和XML、数据存储和查询、事务管理、体系结构等方面的内容。
转载请注明出处:木庄网络博客 » redis实现批量删除的命令介绍