Redis的Hash資料型別

2021-08-14 10:07:30 字數 4436 閱讀 7270

一、概述:

我們可以將redis中的hashes型別看成具有string key和string value的map容器。所以該型別非常適合於儲存值物件的資訊。如username、password和age等。如果hash中包含很少的字段,那麼該型別的資料也將僅占用很少的磁碟空間。每乙個hash可以儲存4294967295個鍵值對。

命令原型 時間複雜度 命令描述 返回值

hset key field value o(1) 為指定的key設定field/value對,如果key不存在,該命令將建立新key以引數中的field/value對,如果引數中的field在該key中已經存在,則用新值覆蓋其原有值。 1表示新的field被設定了新值,0表示field已經存在,用新值覆蓋原有值。

hget key field o(1) 返回指定key中指定field的關聯值。 返回引數中field的關聯值,如果引數中的key或field不存,返回nil。

hexists key field o(1) 判斷指定key中的指定field是否存在。 1表示存在,0表示引數中的field或key不存在。

hlen key o(1) 獲取該key所包含的field的數量。 返回key包含的field數量,如果key不存在,返回0。

hdel key field [field ...] o(n) 時間複雜度中的n表示引數中待刪除的字段數量。從指定key的hashes value中刪除引數中指定的多個字段,如果不存在的字段將被忽略。如果key不存在,則將其視為空hashes,並返回0. 實際刪除的field數量。

hsetnx key field value o(1) 只有當引數中的key或field不存在的情況下,為指定的key設定field/value對,否則該命令不會進行任何操作。 1表示新的field被設定了新值,0表示key或field已經存在,該命令沒有進行任何操作。

hincrby key field increment o(1) 增加指定key中指定field關聯的value的值。如果key或field不存在,該命令將會建立乙個新key或新field,並將其關聯的value初始化為0,之後再指定數字增加的操作。該命令支援的數字是64位有符號整型,即increment可以負數。 返回運算後的值。

hgetall key o(n) 時間複雜度中的n表示key包含的field數量。獲取該鍵包含的所有field/value。其返回格式為乙個field、乙個value,並以此類推。 field/value的列表。

hkeys key o(n) 時間複雜度中的n表示key包含的field數量。返回指定key的所有fields名。 field的列表。

hvals key o(n) 時間複雜度中的n表示key包含的field數量。返回指定key的所有values名。 value的列表。

hmget key field [field ...] o(n) 時間複雜度中的n表示請求的field數量。獲取和引數中指定fields關聯的一組values。如果請求的field不存在,其值返回nil。如果key不存在,該命令將其視為空hash,因此返回一組nil。 返回和請求fields關聯的一組values,其返回順序等同於fields的請求順序。

hmset key field value [field value ...] o(n) 時間複雜度中的n表示被設定的field數量。逐對依次設定引數中給出的field/value對。如果其中某個field已經存在,則用新值覆蓋原有值。如果key不存在,則建立新key,同時設定引數中的field/value。

三、命令示例:

1. hset/hget/hdel/hexists/hlen/hsetnx:

#在shell命令列啟動redis客戶端程式

/> redis-cli

#給鍵值為myhash的鍵設定欄位為field1,值為stephen。

redis 127.0.0.1:6379> hset myhash field1 "stephen"

(integer) 1

#獲取鍵值為myhash,欄位為field1的值。

redis 127.0.0.1:6379> hget myhash field1

"stephen"

#myhash鍵中不存在field2欄位,因此返回nil。

redis 127.0.0.1:6379> hget myhash field2

(nil)

#給myhash關聯的hashes值新增乙個新的字段field2,其值為liu。

redis 127.0.0.1:6379> hset myhash field2 "liu"

(integer) 1

#獲取myhash鍵的字段數量。

redis 127.0.0.1:6379> hlen myhash

(integer) 2

#判斷myhash鍵中是否存在欄位名為field1的字段,由於存在,返回值為1。

redis 127.0.0.1:6379> hexists myhash field1

(integer) 1

#刪除myhash鍵中欄位名為field1的字段,刪除成功返回1。

redis 127.0.0.1:6379> hdel myhash field1

(integer) 1

#再次刪除myhash鍵中欄位名為field1的字段,由於上一條命令已經將其刪除,因為沒有刪除,返回0。

redis 127.0.0.1:6379> hdel myhash field1

(integer) 0

#判斷myhash鍵中是否存在field1欄位,由於上一條命令已經將其刪除,因為返回0。

redis 127.0.0.1:6379> hexists myhash field1

(integer) 0

#通過hsetnx命令給myhash新增新字段field1,其值為stephen,因為該欄位已經被刪除,所以該命令新增成功並返回1。

redis 127.0.0.1:6379> hsetnx myhash field1 stephen

(integer) 1

#由於myhash的field1欄位已經通過上一條命令新增成功,因為本條命令不做任何操作後返回0。

redis 127.0.0.1:6379> hsetnx myhash field1 stephen

(integer) 0

2. hincrby:

#刪除該鍵,便於後面示例的測試。

redis 127.0.0.1:6379> del myhash

(integer) 1

#準備測試資料,該myhash的field欄位設定值1。

redis 127.0.0.1:6379> hset myhash field 5

(integer) 1

#給myhash的field欄位的值加1,返回加後的結果。

redis 127.0.0.1:6379> hincrby myhash field 1

(integer) 6

#給myhash的field欄位的值加-1,返回加後的結果。

redis 127.0.0.1:6379> hincrby myhash field -1

(integer) 5

#給myhash的field欄位的值加-10,返回加後的結果。

redis 127.0.0.1:6379> hincrby myhash field -10

(integer) -5

3. hgetall/hkeys/hvals/hmget/hmset:

#刪除該鍵,便於後面示例測試。

redis 127.0.0.1:6379> del myhash

(integer) 1

#為該鍵myhash,一次性設定多個字段,分別是field1 = "hello", field2 = "world"。

redis 127.0.0.1:6379> hmset myhash field1 "hello" field2 "world"

ok#獲取myhash鍵的多個字段,其中field3並不存在,因為在返回結果中與該字段對應的值為nil。

redis 127.0.0.1:6379> hmget myhash field1 field2 field3

1) "hello"

2) "world"

3) (nil)

#返回myhash鍵的所有字段及其值,從結果中可以看出,他們是逐對列出的。

redis 127.0.0.1:6379> hgetall myhash

1) "field1"

2) "hello"

3) "field2"

4) "world"

#僅獲取myhash鍵中所有欄位的名字。

redis 127.0.0.1:6379> hkeys myhash

1) "field1"

2) "field2"

#僅獲取myhash鍵中所有欄位的值。

redis 127.0.0.1:6379> hvals myhash

1) "hello"

2) "world"

Redis 資料型別 Hash

對一系列儲存的資料進行編組,方便管理,典型應用儲存物件資訊 乙個儲存空間儲存多個鍵值對資料 底層使用雜湊表結構實現資料儲存 注意 hash型別下的value只能儲存字串,不允許儲存其他資料型別,不存在巢狀現象 每個 hash 可以儲存 2 32 1 個鍵值對 hash型別十分貼近物件的資料儲存形式,...

redis資料型別 hash

hash在redis中是一種比較常用的資料型別,資料儲存結構以key value,可以儲存複雜的資料結構,比如 物件,巢狀 list set zset 資料 命令測試127.0.0.1 6379 127.0.0.1 6379 hset ikang name tom integer 1 127.0.0...

Redis資料型別Hash

hash 型別資料操作的注意事項 hash和string型別的區別 有時候我們往往不是在快取中存乙個值,而是選擇存乙個物件,比如乙個購物車訊息,我們就需要使用到hash了 hash儲存的結構會被優化 如果field數量較少,儲存結構優化為類陣列結構 如果field數量較多,儲存結構使用hashmap...