redis學習筆記4(hashes)

2021-12-29 22:16:14 字數 4502 閱讀 8350

redis學習筆記4(hashes)

一、概述:

我們可以將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學習筆記(4)

集合 在集合中每個元素都是不同的,且沒有順序。常用的操作是向集合加入或刪除元素。判斷某個元素是否存在等,由於集合型別在redis內部是使用值為空的三列表實現的,所以這些操作的時間複雜度都是0 1 最方便的是多個集合型別鍵之間還可以進行並集,交集和差運算。命令 1 增加 刪除元素 sadd key m...

Redis學習筆記(4)

為了避免服務的單點故障,會把資料複製到多個副本放在不同的伺服器上,且這些擁有資料副本的伺服器可以用於處理客戶端的讀請求,擴充套件整體的效能。我們把這種機制稱之為主從複製,即master sl e複製機制。主從複製的優勢 讀寫分離 容災恢復 資料冗餘 熱備份 概述 我們可以通過sl eof 命令,或者...

Redis學習筆記4 Redis資料儲存優化機制

1.zipmap優化hash 前面談到將乙個物件儲存在hash型別中會占用更少的記憶體,並且可以更方便的訪問整個物件。省記憶體的原因是新建乙個hash物件時開始是用zipmap來儲存的。這個zipmap其實並不是hash table,但是zipmap相比正常的hash實現可以節省不少hash本身需要...