Redis學習手冊(Hashes資料型別)

工程師WWW發表於2016-02-01

一、概述:

      我們可以將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的列表。 
HMGETkey field [field ...]  O(N)  時間複雜度中的N表示請求的Field數量。獲取和引數中指定Fields關聯的一組Values。如果請求的Field不存在,其值返回nil。如果Key不存在,該命令將其視為空Hash,因此返回一組nil。 返回和請求Fields關聯的一組Values,其返回順序等同於Fields的請求順序。
HMSETkey 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" 

相關文章