1. 獲取指定首碼的key 需求描述: Redis中有大量以xxx開頭的key,在不使用keys命令的情況下,如何快速獲取這些首碼的key 解決方案: redis自帶的scan命令可以解決這個問題 2. SCAN命令 SCAN是一個基於游標的迭代器。這意味著在每次調用該命令時,伺服器都會返回一個更新 ...
1. 獲取指定首碼的key
需求描述:
Redis中有大量以xxx開頭的key,在不使用keys命令的情況下,如何快速獲取這些首碼的key
解決方案:
redis自帶的scan命令可以解決這個問題
2. SCAN命令
SCAN是一個基於游標的迭代器。這意味著在每次調用該命令時,伺服器都會返回一個更新後的游標,用戶需要在下一次調用中使用它作為游標參數。當游標設置為0時開始迭代,當伺服器返回的游標為0時終止迭代。從游標值為0開始迭代,並調用SCAN直到返回的游標再次為0,這稱為完整迭代。
時間複雜度:每次調用 O(1)。O(N) 用於完整的迭代,包括足夠的命令調用以使游標返回 0。N 是集合內的元素數。
和scan命令相關的還有另外3個命令,分別是:
- SCAN 迭代當前選定的Redis資料庫中的一組鍵
- SSCAN 迭代 Sets 類型的元素
- HSCAN 迭代 Hash 類型的欄位及其相關值
- ZSCAN 迭代 Sorted Set 類型的元素及其相關分數
語法:
SCAN cursor [MATCH pattern] [COUNT count] [TYPE type]
選項:
MATCH選項
和KEYS命令類似,後面可以跟一個通配符
COUNT選項
SCAN不能保證每次迭代返回的元素數量,但可以使用COUNT選項根據經驗調整SCAN的行為。基本上,使用COUNT,用戶指定了每次調用時從集合中檢索元素所需完成的工作量。這隻是實現的一個提示,但是一般來說,但是在大多數情況下,這種提示都是有效的(在數據量少的情況下,COUNT值與返回的結果數量不相等)。
TYPE選項
可以使用 TYPE 選項要求 SCAN 僅返回與給定類型匹配的對象。 TYPE 選項僅在整個資料庫 SCAN 上可用,而不是 HSCAN 或 ZSCAN 等。