1. 程式人生 > >redis學習(四)——Hash資料型別

redis學習(四)——Hash資料型別

一、概述

      我們可以將Redis中的Hash型別看成具有String Key和String Value的map容器。所以該型別非常適合於儲存值物件的資訊。如Username、Password和Age等。如果Hash中包含很少的欄位,那麼該型別的資料也將僅佔用很少的磁碟空間。每一個Hash可以儲存4294967295個鍵值對。

二、相關命令

1、賦值命令

命令原型:HSET key field value

時間複雜度:O(1)

命令描述:為指定的Key設定Field/Value對,如果Key不存在,該命令將建立新Key以用於儲存引數中的Field/Value對,如果引數中的Field在該Key中已經存在,則用新值覆蓋其原有值。 

返回值:1表示新的Field被設定了新值,0表示Field已經存在,用新值覆蓋原有值。

2、取值命令

命令原型:HGET key field

時間複雜度:O(1)

命令描述:返回指定Key中指定Field的關聯值。

返回值:返回引數中Field的關聯值,如果引數中的Key或Field不存在,返回nil。

3、判斷欄位是否存在

命令原型:HEXISTS key field

時間複雜度:O(1)

命令描述:判斷指定Key中的指定Field是否存在。

返回值:1表示存在,0表示引數中的Field或Key不存在。

4、獲得欄位數量 

命令原型:HLEN key

時間複雜度:O(1)

命令描述:獲取該Key所包含的Field的數量。

返回值:

返回Key包含的Field數量,如果Key不存在,返回0。

5、刪除欄位 

命令原型:HDEL key field [field ...] 

時間複雜度:O(N)

命令描述:時間複雜度中的N表示引數中待刪除的欄位數量。從指定Key的Hashes Value中刪除引數中指定的多個欄位,如果不存在的欄位將被忽略。如果Key不存在,則將其視為空Hashes,並返回0。

返回值:實際刪除的Field數量。

6、當欄位不存在時賦值

命令原型:HSETNX key field value

時間複雜度:O(1)

命令描述:只有當引數中的Key或Field不存在的情況下,為指定的Key設定Field/Value對,否則該命令不會進行任何操作。 

返回值:1表示新的Field被設定了新值,0表示Key或Field已經存在,該命令沒有進行任何操作。

7、增加數字

命令原型:HINCRBY key field increment 

時間複雜度:O(1)

命令描述:增加指定Key中指定Field關聯的Value的值。如果Key或Field不存在,該命令將會建立一個新Key或新Field,並將其關聯的Value初始化為0,之後再指定數字增加的操作。該命令支援的數字是64位有符號整型,即increment可以負數。 

返回值:返回運算後的值。

8、獲取指定鍵中所有的欄位/值

命令原型:HGETALL key

時間複雜度:O(N)

命令描述:時間複雜度中的N表示Key包含的Field數量。獲取該鍵包含的所有Field/Value。其返回格式為一個Field、一個Value,並以此類推。

返回值:Field/Value的列表。

9、只獲取欄位名

命令原型:HKEYS key 

時間複雜度:O(N)

命令描述:時間複雜度中的N表示Key包含的Field數量。返回指定Key的所有Fields名。

返回值:Field的列表。

10、只獲取欄位值

命令原型:HVALS key 

時間複雜度:O(N)

命令描述:時間複雜度中的N表示Key包含的Field數量。返回指定Key的所有Values名。

返回值:value的列表。

11、設定多個欄位的值

命令原型:HMSET key field value [field value ...]

時間複雜度:O(N)

命令描述:時間複雜度中的N表示被設定的Field數量。逐對依次設定引數中給出的Field/Value對。如果其中某個Field已經存在,則用新值覆蓋原有值。如果Key不存在,則建立新Key,同時設定引數中的Field/Value。  

返回值:

12、獲取多個欄位的值

命令原型:HMGET key field [field ...] 

時間複雜度:O(N)

命令描述:時間複雜度中的N表示請求的Field數量。獲取和引數中指定Fields關聯的一組Values。如果請求的Field不存在,其值返回nil。如果Key不存在,該命令將其視為空Hash,因此返回一組nil。

返回值:返回和請求Fields關聯的一組Values,其返回順序等同於Fields的請求順序。

三、命令示例:

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"