首頁 > 資料庫 > Redis > 主體

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

王林
發布: 2023-05-31 08:59:00
轉載
1668 人瀏覽過

遇到的問題:

在開發過程中,會遇到要批次刪除某種規則的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
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!