首頁 >資料庫 >Redis >redis批量刪除key值的問題怎麼解決

redis批量刪除key值的問題怎麼解決

王林
王林轉載
2023-05-31 08:59:001756瀏覽

遇到的問題:

在開發過程中,會遇到要批次刪除某種規則的key,例如login_logID(ID為變數),現在需要刪除"login_log*"這一類的數據,但是redis本身只有批量查詢一類key值的命令keys,但是沒有批量刪除某一個類的命令。

解決方法:

先查詢,在刪除,使用xargs傳參(xargs可以將管道或標準輸入(stdin)資料轉換成命令列參數),先執行查詢語句,在將查詢出來的key值,當初del的參數去刪除。

redis-cli  KEYS key* (查找条件) | xargs redis-cli  del

=>[執行後回傳的結果影響數量]:(integer) 10[數量10個]
做個實驗,先創三個同類型的key值

127.0.0.1:6379> set test1 1
OK
127.0.0.1:6379> set test2 2
OK
127.0.0.1:6379> set test3
127.0.0.1:6379> set test3 3

127.0.0.1:6379> set test3 3
127.0.0.1:6379> set test3 3

查詢keys



127.0.0.1:6379> keys test*
1) "test3"

2) "test2"
3) " test1"

退出redis,在本地執行刪除指令

[root@localhost redis]# redis-cli -a 密码 -n 0(数据库) keys "test*" |xargs redis-cli -a 密码 -n 0(数据库)  del
Warning: Using a password with '-a' or '-u' option on the command line interface may not be safe.
Warning: Using a password with '-a' or '-u' option on the command line interface may not be safe.
(integer) 3 (返回行数)

原理解析:
  這個指令是先透過redis客戶端執行了keys指令,模糊搜尋出所有的key,透過xargs指令,將前面查詢出來的key當作後面redis的del指令的輸入相當於執行了redis-cli del test1 test2 test3
注意:這裡執行時需要帶上redis條件,-a是輸入密碼,-n是指定資料庫,如果redis不在本地或其他有變動還需要加上-h redis所在伺服器ip,-p連接埠

例如

redis-cli -h 127.0.0.1(IP位址) -p 6379 (埠號) -a 密碼-n 1(資料在第幾個函式庫就寫幾) KEYS key* (查找條件) | xargs redis-cli ( -h (IP位址) -p 6379 (埠號) -a 密碼-n 1 ) del

補充知識:

redis中的刪除

1.Redis DEL指令用於刪除已存在的鍵,不存在的key 會被忽略。
例如:



127.0.0.1:6379> set hello world
OK

127.0.0.1:6379> del hello
(integer) 1



但是del只能刪除一個或多個,不能批次刪除,當需要刪除資料量過大時就不適用了

2.清空整個Redis 伺服器的資料:flushall###3.清空當前庫中的所有key:flushdb###

以上是redis批量刪除key值的問題怎麼解決的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:yisu.com。如有侵權,請聯絡admin@php.cn刪除