11 Redis 哈希(Hash)

Redis hash 是一個(gè)string類型的field和value的映射表,hash特別適合用于存儲(chǔ)對(duì)象。
Redis 中每個(gè) hash 可以存儲(chǔ) 232 - 1 鍵值對(duì)(40多億)。

  • 實(shí)例

127.0.0.1:6379> HMSET runoobkey name "redis tutorial" description "redis basic commands for caching" likes 20 visitors 23000\
OK
127.0.0.1:6379> HGETALL runoobkey
1) "name"
2) "redis tutorial"
3) "description"
4) "redis basic commands for caching"
5) "likes"
6) "20"
7) "visitors"
8) "23000\\"


在以上實(shí)例中,我們設(shè)置了 redis 的一些描述信息(name, description, likes, visitors) 到哈希表的 runoobkey 中。

Redis hash 命令

下表列出了 redis hash 基本的相關(guān)命令:

  • 1 Hdel

Redis Hdel 命令用于刪除哈希表 key 中的一個(gè)或多個(gè)指定字段,不存在的字段將被忽略。

# 語法
redis 127.0.0.1:6379> HDEL KEY_NAME FIELD1.. FIELDN 


# 返回值
被成功刪除字段的數(shù)量,不包括被忽略的字段。

# 實(shí)例
127.0.0.1:6379> HSET myhash field1 "foo"
(integer) 1
127.0.0.1:6379> HGETall myhash
1) "field1"
2) "foo"
127.0.0.1:6379> HDEL myhash field1
(integer) 1
127.0.0.1:6379> Hgetall myhash
(empty list or set)
127.0.0.1:6379> HDEL myhash2 field1
(integer) 0
  • 2 Hexists

Redis Hexists 命令用于查看哈希表的指定字段是否存在。

# 語法
redis 127.0.0.1:6379> HEXISTS KEY_NAME FIELD_NAME 


# 返回值
如果哈希表含有給定字段,返回 1 。 如果哈希表不含有給定字段,或 key 不存在,返回 0 。

# 實(shí)例
127.0.0.1:6379> HSET myhash field1 "foo"
(integer) 1
127.0.0.1:6379> HEXISTS myhash field1
(integer) 1
127.0.0.1:6379> HEXISTS myhash field2
(integer) 0
  • 3 Hget

Redis Hget 命令用于返回哈希表中指定字段的值。

# 語法
redis 127.0.0.1:6379> HGET KEY_NAME FIELD_NAME 


# 返回值
返回給定字段的值。如果給定的字段或 key 不存在時(shí),返回 nil 。

# 實(shí)例

# 字段存在
127.0.0.1:6379> HSET site redis redis.com
(integer) 1
127.0.0.1:6379> HGET site redis
"redis.com"


# 字段不存在
127.0.0.1:6379> HGET site mysql
(nil)
  • 4 Hgetall

Redis Hgetall 命令用于返回哈希表中,所有的字段和值。
在返回值里,緊跟每個(gè)字段名(field name)之后是字段的值(value),所以返回值的長度是哈希表大小的兩倍。

# 語法
redis 127.0.0.1:6379> HGETALL KEY_NAME 


# 返回值
以列表形式返回哈希表的字段及字段值。 若 key 不存在,返回空列表。


# 實(shí)例

127.0.0.1:6379> HSET myhash field1 "Hello"
(integer) 1
127.0.0.1:6379> HSET myhash field2 "World"
(integer) 1
127.0.0.1:6379> HGETALL myhash
1) "field1"
2) "Hello"
3) "field2"
4) "World"
  • 5 Hincrby

Redis Hincrby 命令用于為哈希表中的字段值加上指定增量值。
增量也可以為負(fù)數(shù),相當(dāng)于對(duì)指定字段進(jìn)行減法操作。
如果哈希表的 key 不存在,一個(gè)新的哈希表被創(chuàng)建并執(zhí)行 HINCRBY 命令。
如果指定的字段不存在,那么在執(zhí)行命令前,字段的值被初始化為 0 。
對(duì)一個(gè)儲(chǔ)存字符串值的字段執(zhí)行 HINCRBY 命令將造成一個(gè)錯(cuò)誤。
本操作的值被限制在 64 位(bit)有符號(hào)數(shù)字表示之內(nèi)。

# 語法
redis 127.0.0.1:6379> HINCRBY KEY_NAME FIELD_NAME INCR_BY_NUMBER 

# 返回值
執(zhí)行 HINCRBY 命令之后,哈希表中字段的值。


# 實(shí)例

# 對(duì)已存在的鍵進(jìn)行設(shè)置
127.0.0.1:6379> HSET myhash field 5
(integer) 1
127.0.0.1:6379> HINCRBY myhash field 1
(integer) 6
127.0.0.1:6379> HINCRBY myhash field -10
(integer) -4 
  • 6 Hincrbyfloat

Redis Hincrbyfloat 命令用于為哈希表中的字段值加上指定浮點(diǎn)數(shù)增量值。
如果指定的字段不存在,那么在執(zhí)行命令前,字段的值被初始化為 0 。

# 語法
redis 127.0.0.1:6379> HINCRBYFLOAT KEY_NAME FIELD_NAME INCR_BY_NUMBER 


# 返回值
執(zhí)行 Hincrbyfloat 命令之后,哈希表中字段的值。


# 實(shí)例
127.0.0.1:6379> HSET mykey field 10.50
(integer) 1
127.0.0.1:6379> HINCRBYFLOAT mykey field 0.1
"10.6"
127.0.0.1:6379> HINCRBYFLOAT mykey field -5
"5.6"
127.0.0.1:6379> HSET mykey field 5.0e3
(integer) 0
127.0.0.1:6379> hINCRBYFLOAT mykey field 2.0e2
"5200"
  • 7 Hkeys

Redis Hkeys 命令用于獲取哈希表中的所有域(field)。

# 語法
redis 127.0.0.1:6379> HKEYS KEY_NAME FIELD_NAME INCR_BY_NUMBER 


# 返回值
包含哈希表中所有域(field)列表。 當(dāng) key 不存在時(shí),返回一個(gè)空列表。


# 實(shí)例

127.0.0.1:6379> HSET myhash field1 "foo"
(integer) 1
127.0.0.1:6379> HSET myhash field2 "bar"
(integer) 1
127.0.0.1:6379> HKEYS myhash
1) "field1"
2) "field2"
  • 8 Hlen

Redis Hlen 命令用于獲取哈希表中字段的數(shù)量。

# 語法
redis 127.0.0.1:6379> HLEN KEY_NAME 


# 返回值
哈希表中字段的數(shù)量。 當(dāng) key 不存在時(shí),返回 0 。


# 實(shí)例
redis 127.0.0.1:6379> HSET myhash field1 "foo"
(integer) 1
redis 127.0.0.1:6379> HSET myhash field2 "bar"
(integer) 1
redis 127.0.0.1:6379> HLEN myhash
(integer) 2
  • 9 Hmget

Redis Hmget 命令用于返回哈希表中,一個(gè)或多個(gè)給定字段的值。
如果指定的字段不存在于哈希表,那么返回一個(gè) nil 值。

# 語法
redis 127.0.0.1:6379> HMGET KEY_NAME FIELD1...FIELDN 

# 返回值
一個(gè)包含多個(gè)給定字段關(guān)聯(lián)值的表,表值的排列順序和指定字段的請求順序一樣。


# 實(shí)例

# 對(duì)已存在的鍵進(jìn)行設(shè)置
127.0.0.1:6379> HSET myhash field1 "foo"
(integer) 1
127.0.0.1:6379> HSET myhash field2 "bar"
(integer) 1
127.0.0.1:6379> HMGET myhash field1 field2 nofield
1) "foo"
2) "bar"
3) (nil)
  • 10 Hmset

Redis Hmset 命令用于同時(shí)將多個(gè) field-value (字段-值)對(duì)設(shè)置到哈希表中。
此命令會(huì)覆蓋哈希表中已存在的字段。
如果哈希表不存在,會(huì)創(chuàng)建一個(gè)空哈希表,并執(zhí)行 HMSET 操作。

# 語法
redis 127.0.0.1:6379> HMSET KEY_NAME FIELD1 VALUE1 ...FIELDN VALUEN  


# 返回值
如果命令執(zhí)行成功,返回 OK 。


# 實(shí)例

# 對(duì)已存在的鍵進(jìn)行設(shè)置
127.0.0.1:6379> HMSET myhash field1 "Hello" field2 "World"
OK
127.0.0.1:6379> HGET myhash field1
"Hello" 
127.0.0.1:6379> HGET myhash field2
"World"
  • 11 Hset

Redis Hset 命令用于為哈希表中的字段賦值 。
如果哈希表不存在,一個(gè)新的哈希表被創(chuàng)建并進(jìn)行 HSET 操作。
如果字段已經(jīng)存在于哈希表中,舊值將被覆蓋。


# 語法
redis 127.0.0.1:6379> HSET KEY_NAME FIELD VALUE 

# 返回值
如果字段是哈希表中的一個(gè)新建字段,并且值設(shè)置成功,返回 1 。 如果哈希表中域字段已經(jīng)存在且舊值已被新值覆蓋,返回 0 。


# 實(shí)例
127.0.0.1:6379> HSET myhash field1 "foo"
(integer) 1
127.0.0.1:6379> HGET myhash field1
"foo"
127.0.0.1:6379> HSET website google "www.g.cn"               # 設(shè)置一個(gè)新域
(integer) 1
127.0.0.1:6379> HSET website google "www.google.com"        # 覆蓋一個(gè)舊域
(integer) 0
127.0.0.1:6379> HGET website google
"www.google.com"

  • 12 Hsetnx

Redis Hsetnx 命令用于為哈希表中不存在的的字段賦值 。
如果哈希表不存在,一個(gè)新的哈希表被創(chuàng)建并進(jìn)行 HSET 操作。
如果字段已經(jīng)存在于哈希表中,操作無效。
如果 key 不存在,一個(gè)新哈希表被創(chuàng)建并執(zhí)行 HSETNX 命令。

# 語法
redis 127.0.0.1:6379> HSETNX KEY_NAME FIELD VALUE


# 返回值
設(shè)置成功,返回 1 。 如果給定字段已經(jīng)存在且沒有操作被執(zhí)行,返回 0 。


# 實(shí)例

redis 127.0.0.1:6379> HSETNX myhash field1 "foo"        # 操作無效, field1 已存在
(integer) 1
redis 127.0.0.1:6379> HSETNX myhash field1 "bar"     
(integer) 0
redis 127.0.0.1:6379> HGET myhash field1 
"foo"
  • 13 Hvals

Redis Hvals 命令返回哈希表所有域(field)的值。

# 語法
redis 127.0.0.1:6379> HVALS KEY_NAME FIELD VALUE 

# 返回值
一個(gè)包含哈希表中所有域(field)值的列表。 當(dāng) key 不存在時(shí),返回一個(gè)空表。


# 實(shí)例

127.0.0.1:6379> HSET myhash field1 "foo"
(integer) 1
127.0.0.1:6379> HSET myhash field2 "bar"
(integer) 1
127.0.0.1:6379> HVALS myhash
1) "foo"
2) "bar"

# 空哈希表/不存在的key
127.0.0.1:6379> exists 666
(integer) 0
127.0.0.1:6379> havls 666
(error) ERR unknown command 'havls'
127.0.0.1:6379> hvals 666
(empty list or set)

  • 14 HSCAN

迭代哈希表中的鍵值對(duì)。

# 語法
HSCAN key cursor [MATCH pattern] [COUNT count] 


# 返回值
哈希表中的鍵值對(duì)


# 實(shí)例
127.0.0.1:6379> hscan myhash 0
1) "0"
2) 1) "field1"
   2) "foo"
   3) "field2"
   4) "bar"

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容