命令原型 | 時間復雜度 | 命令描述 | 返回值 |
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的請求順序。 |
HMSET key field value [field value ...] | O(N) | 時間復雜度中的N表示被設置的Field數量。逐對依次設置參數中給出的Field/Value對。如果其中某個Field已經存在,則用新值覆蓋原有值。如果Key不存在,則創建新Key,同時設定參數中的Field/Value。 |
三、命令示例:
1. HSET/HGET/HDEL/HEXISTS/HLEN/HSETNX: