一:Redis 哈希(Hash)
Redis hash 是一個string類型的field和value的映射表,hash特別適合用於存儲對象。
Redis 中每個 hash 可以存儲 232 - 1 鍵值對(40多億).
redis中Hash在內存中的存儲格式如下圖

--------------------------------------------------------------------
二:hash常用命令
1)hset(name, key, value) name對應的hash中設置一個鍵值對(不存在,則創建;否則,修改)
2)hmset(name, mapping) 在name對應的hash中批量設置鍵值對
3)hget(name,key) 在name對應的hash中獲取根據key獲取value
4)hmget(name, keys, *args) 在name對應的hash中獲取多個key的值
5)hgetall(name) 獲取name對應hash的所有鍵值
6)hlen(name) 獲取name對應的hash中鍵值對的個數
7)hkeys(name) 獲取name對應的hash中所有的key的值
8)hvals(name) 獲取name對應的hash中所有的value的值
9)hexists(name, key) 檢查name對應的hash是否存在當前傳入的key
10)hdel(name,*keys) 將name對應的hash中指定key的鍵值對刪除
11)hincrby(name, key, amount=1) 自增name對應的hash中的指定key的值,不存在則創建key=amount
12)hincrbyfloat(name, key, amount=1.0) 自增name對應的hash中的指定key的值,不存在則創建key=amount
13)hscan(name, cursor=0, match=None, count=None) 迭代哈希表中的鍵值對
14)hscan_iter(name, match=None, count=None) 利用yield封裝hscan創建生成器,實現分批去redis中獲取數據
三:示例
[BEGIN] 2017/7/29 21:29:50 127.0.0.1:6379> HSET n1 k1 "shi" 生成一個hash 一個鍵值對 (integer) 1 127.0.0.1:6379> HSET n2 k2 "san" k3 "jun" 生成hash 批量鍵值對 (integer) 2 127.0.0.1:6379> HGET n1 k1 hash中獲取根據key獲取value "shi" 127.0.0.1:6379> HMGET n2 k2 k3 對應的hash中獲取多個key的值 1) "san" 2) "jun" 127.0.0.1:6379> HGETALL n2 hash的所有鍵值 1) "k2" 2) "san" 3) "k3" 4) "jun" 127.0.0.1:6379> HLEN n2 對應的hash中鍵值對的個數 (integer) 2 127.0.0.1:6379> HKEYS n2 對應的hash中所有的key的值 1) "k2" 2) "k3" 127.0.0.1:6379> HVALS n2 對應的hash中所有的value的值 1) "san" 2) "jun" 127.0.0.1:6379> HEXISTS n2 k2 對應的hash是否存在當前傳入的key (integer) 1 127.0.0.1:6379> HEXISTS n2 k1 (integer) 0 127.0.0.1:6379> HDEL n2 k2 對應的hash中指定key的鍵值對刪除 (integer) 1 127.0.0.1:6379> HGET n2 k2 (nil) 127.0.0.1:6379> HINCRBY n2 k3 2 自增name對應的hash中的指定key的值,不存在則創建key=amount (error) ERR hash value is not an integer 127.0.0.1:6379> HSET n2 k4 1 (integer) 1 127.0.0.1:6379> HINCRBY n2 k4 1 (integer) 2 127.0.0.1:6379> HINCRBYFLOAT n2 k4 2.3 "4.3" 127.0.0.1:6379> HSCAN n2 0 match j* 1) "0" 2) (empty list or set) 127.0.0.1:6379> HSCAN n2 0 match k* 迭代哈希表中的鍵值對 1) "0" 2) 1) "k3" 2) "jun" 3) "k4" 4) "4.3" 127.0.0.1:6379> HSCAN_iter n2 match k* (error) ERR unknown command 'HSCAN_iter' [END] 2017/7/29 21:43:48
