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本身需要...