一、概述:
我們可以將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。 |
HEXISTSkey 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數量。 |
HSETNXkey field value |
O(1) |
只有當參數中的Key或Field不存在的情況下,為指定的Key設定Field/Value對,否則該命令不會進行任何操作。 |
1表示新的Field被設定了新值,0表示Key或Field已經存在,該命令沒有進行任何操作。 |
HINCRBYkey field increment |
O(1) |
增加指定Key中指定Field關聯的Value的值。如果Key或Field不存在,該命令將會建立一個新Key或新Field,並將其關聯的Value初始化為0,之後再指定數字增加的操作。該命令支援的數字是64位有符號整型,即increment可以負數。 |
返回運算後的值 |
HGETALLkey |
O(N) |
時間複雜度中的N表示Key包含的Field數量。擷取該鍵包含的所有Field/Value。其返回格式為一個Field、一個Value,並以此類推。 |
Field/Value的列表 |
HKEYSkey |
O(N) |
時間複雜度中的N表示Key包含的Field數量。返回指定Key的所有Fields名。 |
Field的列表。 |
HVALSkey |
O(N) |
時間複雜度中的N表示Key包含的Field數量。返回指定Key的所有Values名。 |
Value的列表。 |
MGETkey 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教程(四):Hashes資料類型的內容,更多相關內容請關注topic.alibabacloud.com(www.php.cn)!