redis实现批量删除的命令介绍


本文摘自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》频道 >>


数据库系统概念 第6版
书籍

数据库系统概念 第6版

机械工业出版社

本书主要讲述了数据模型、基于对象的数据库和XML、数据存储和查询、事务管理、体系结构等方面的内容。



打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...