Redis Keys: SCAN
Redis SCAN Command
The Redis SCAN command is used in order to incrementally iterate over a collection of elements.
Basic usage of SCAN
- SCAN is a cursor based iterator. This means that at every call of the command, the server returns an updated cursor that the user needs to use as the cursor argument in the next call.
- An iteration starts when the cursor is set to 0 and terminates when the cursor returned by the server is 0. The following is an example of SCAN iteration:
Syntax:
SCAN cursor [MATCH pattern] [COUNT count]
Available since
2.8.0.
Return Value
SCAN return value is an array of two values:
- the first value is the new cursor to use in the next call, the second value is an array of elements
- Since in the second call the returned cursor is 0, the server signaled to the caller that the iteration finished, and the collection was completely explored.
- Starting an iteration with a cursor value of 0, and calling SCAN until the returned cursor is 0 again is called a full iteration.
Return Value Type
Array
Example: Redis SCAN key
127.0.0.1:6379> SCAN 0 1) "1" 2) 1) "numbers" 2) "hash key" 3) "myhash" 4) "myset" 5) "w3rkey" 6) "user-v" 7) "languages" 8) "mycolor1" 9) "user-x" 10) "key1" 11) "key" 12) "string key"
Available count
How is the scan cursor count 10.
The specified key and count the number of queries that do not always fit perfectly. In consideration of the processing time and controlling the number.
Example: Redis SCAN count 10
127.0.0.1:6379> SCAN 0 count 10 1) "1" 2) 1) "numbers" 2) "hash key" 3) "myhash" 4) "myset" 5) "w3rkey" 6) "user-v" 7) "languages" 8) "mycolor1" 9) "user-x" 10) "key1" 11) "key" 12) "string key"
Enable pattern
The usage scan cursor match pattern.
The lookup key only meets the specified pattern.
The GLOB style pattern.
Example: Redis SCAN match key*
127.0.0.1:6379> SCAN 0 match key* 1) "1" 2) 1) "key1" 2) "key"
Example: Redis HSCAN another example
127.0.0.1:6379> HMSET nhash name Sachin age 40 OK 127.0.0.1:6379> HSCAN nhash 0 1) "0" 2) 1) "name" 2) "Sachin" 3) "age" 4) "40"
- Weekly Trends and Language Statistics
- Weekly Trends and Language Statistics