Redis的Hash類型及相關(guān)命令小結(jié)
HSET
設(shè)置 hash 中指定的字段(field)的值(value)。
語法
HSET key field value [field value ...]
時間復(fù)雜度:插??組 field 為 O(1), 插? N 組 field 為 O(N)
返回值:添加的字段的個數(shù)。
舉例
redis> HSET myhash field1 "Hello" (integer) 1 redis> HGET myhash field1 "Hello" redis> HSET myhash field2 "Hi" field3 "World" (integer) 2 redis> HGET myhash field2 "Hi" redis> HGET myhash field3 "World" redis> HGETALL myhash 1) "field1" 2) "Hello" 3) "field2" 4) "Hi" 5) "field3" 6) "World"
HGET
獲取 hash 中指定字段的值。
語法
HGET key field
時間復(fù)雜度:O(1)
返回值:字段對應(yīng)的值或者 nil。
舉例
redis> HSET myhash field1 "foo" (integer) 1 redis> HGET myhash field1 "foo" redis> HGET myhash field2 (nil)
HEXISTS
判斷 hash 中是否有指定的字段。
語法
HEXISTS key field
時間復(fù)雜度:O(1)
返回值:1 表?存在,0 表?不存在。
舉例
redis> HSET myhash field1 "foo" (integer) 1 redis> HEXISTS myhash field1 (integer) 1 redis> HEXISTS myhash field2 (integer) 0
HDEL
刪除 hash 中指定的字段。
語法
HDEL key field [field ...]
時間復(fù)雜度:刪除?個元素為 O(1). 刪除 N 個元素為 O(N).
返回值:本次操作刪除的字段個數(shù)。
舉例
redis> HSET myhash field1 "foo" (integer) 1 redis> HDEL myhash field1 (integer) 1 redis> HDEL myhash field2 (integer) 0
HKEYS
獲取 hash 中的所有字段。
語法
HKEYS key
時間復(fù)雜度:O(N), N 為 field 的個數(shù).
返回值:字段列表。
舉例
redis> HSET myhash field1 "Hello" (integer) 1 redis> HSET myhash field2 "World" (integer) 1 redis> HKEYS myhash 1) "field1" 2) "field2"
HVALS
獲取 hash 中的所有的值。
語法
HVALS key
時間復(fù)雜度:O(N), N 為 field 的個數(shù).
返回值:所有的值。
舉例
redis> HSET myhash field1 "Hello" (integer) 1 redis> HSET myhash field2 "World" (integer) 1 redis> HVALS myhash 1) "Hello" 2) "World"
HGETALL
獲取 hash 中的所有字段以及對應(yīng)的值。
語法
HGETALL key
時間復(fù)雜度:O(N), N 為 field 的個數(shù).
返回值:字段和對應(yīng)的值。
舉例
redis> HSET myhash field1 "Hello" (integer) 1 redis> HSET myhash field2 "World" (integer) 1 redis> HGETALL myhash 1) "field1" 2) "Hello" 3) "field2" 4) "World"
HMGET
?次獲取 hash 中多個字段的值。
語法
HMGET key field [field ...]
時間復(fù)雜度:只查詢?個元素為 O(1), 查詢多個元素為 O(N), N 為查詢元素個數(shù).
返回值:字段對應(yīng)的值或者 nil。
舉例
redis> HSET myhash field1 "Hello" (integer) 1 redis> HSET myhash field2 "World" (integer) 1 redis> HMGET myhash field1 field2 nofield 1) "Hello" 2) "World" 3) (nil)
HLEN
獲取 hash 中的所有字段的個數(shù)。
語法
HLEN key
時間復(fù)雜度:O(1)
返回值:字段個數(shù)。
舉例
redis> HSET myhash field1 "Hello" (integer) 1 redis> HSET myhash field2 "World" (integer) 1 redis> HLEN myhash (integer) 2
HSETNX
在字段不存在的情況下,設(shè)置 hash 中的字段和值。
語法
HSETNX key field value
時間復(fù)雜度:O(1)
返回值:1 表?設(shè)置成功,0 表?失敗。
舉例
redis> HSETNX myhash field "Hello" (integer) 1 redis> HSETNX myhash field "World" (integer) 0 redis> HGET myhash field "Hello"
HINCRBY
將 hash 中字段對應(yīng)的數(shù)值添加指定的值。
語法
HINCRBY key field increment
時間復(fù)雜度:O(1)
返回值:該字段變化之后的值。
舉例
redis> HSET myhash field 5 (integer) 1 redis> HINCRBY myhash field 1 (integer) 6 redis> HINCRBY myhash field -1 (integer) 5 redis> HINCRBY myhash field -10 (integer) -5
HINCRBYFLOAT
HINCRBY 的浮點數(shù)版本。
語法
HINCRBYFLOAT key field increment
時間復(fù)雜度:O(1)
返回值:該字段變化之后的值。
舉例
redis> HSET mykey field 10.50 (integer) 1 redis> HINCRBYFLOAT mykey field 0.1 "10.6" redis> HINCRBYFLOAT mykey field -5 "5.6" redis> HSET mykey field 5.0e3 (integer) 0 redis> HINCRBYFLOAT mykey field 2.0e2 "5200"
內(nèi)部編碼
哈希的內(nèi)部編碼有兩種:
ziplist(壓縮列表):當(dāng)哈希類型元素個數(shù)?于 hash-max-ziplist-entries 配置(默認(rèn) 512 個)、同時所有值都?于 hash-max-ziplist-value 配置(默認(rèn) 64 字節(jié))時,Redis 會使? ziplist 作為哈希的內(nèi)部實現(xiàn),ziplist 使?更加緊湊的結(jié)構(gòu)實現(xiàn)多個元素的連續(xù)存儲,所以在節(jié)省內(nèi)存???hashtable 更加優(yōu)秀。
hashtable(哈希表):當(dāng)哈希類型?法滿? ziplist 的條件時,Redis 會使? hashtable 作為哈希的內(nèi)部實現(xiàn),因為此時 ziplist 的讀寫效率會下降,? hashtable 的讀寫時間復(fù)雜度為 O(1)。
下?的?例演?了哈希類型的內(nèi)部編碼,以及響應(yīng)的變化。
1)當(dāng) field 個數(shù)?較少且沒有?的 value 時,內(nèi)部編碼為 ziplist:
127.0.0.1:6379> hmset hashkey f1 v1 f2 v2
OK
127.0.0.1:6379> object encoding hashkey
"ziplist”
2)當(dāng)有 value ?于 64 字節(jié)時,內(nèi)部編碼會轉(zhuǎn)換為 hashtable:
127.0.0.1:6379> hset hashkey f3 "one string is bigger than 64 bytes ... 省略 ..."
OK
127.0.0.1:6379> object encoding hashkey
"hashtable"
3)當(dāng) field 個數(shù)超過 512 時,內(nèi)部編碼也會轉(zhuǎn)換為 hashtable:
127.0.0.1:6379> hmset hashkey f1 v1 h2 v2 f3 v3 ... 省略 ... f513 v513
OK
127.0.0.1:6379> object encoding hashkey
"hashtable"
應(yīng)用場景
1.緩存數(shù)據(jù)
類似于String類型,Hash類型也可以用于緩存數(shù)據(jù)。不過,由于Hash類型可以存儲多個字段和字段值,因此更適合用于緩存具有多個屬性的數(shù)據(jù)。
例如,可以將經(jīng)常訪問的商品信息、用戶信息等緩存在Hash類型中,以便快速讀取和響應(yīng)客戶端請求。
2.對象屬性存儲
Hash類型非常適合存儲對象的各個屬性,如用戶信息、商品信息等??梢詫ο箢悇e和ID構(gòu)成鍵名,使用字段表示對象的屬性,而字段值則存儲屬性值。例如,要存儲ID為1的汽車對象,可以分別使用名為color、name和price的字段來存儲該輛汽車的顏色、名稱和價格。
同樣,對于用戶信息,可以將用戶的ID作為Hash類型的鍵,用戶的各種屬性(如用戶名、年齡、性別等)作為字段和字段值進行存儲。
到此這篇關(guān)于Redis的Hash類型及相關(guān)命令小結(jié)的文章就介紹到這了,更多相關(guān)Redis Hash類型內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
解決linux下redis數(shù)據(jù)庫overcommit_memory問題
這篇文章介紹了解決linux下redis數(shù)據(jù)庫overcommit_memory問題的方法,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-02-02通過prometheus監(jiān)控redis實時運行狀態(tài)的操作方法
本文詳細(xì)介紹了如何通過Prometheus監(jiān)控Redis的運行狀態(tài),包括安裝配置Redis、Redis Exporter以及Prometheus,配置Prometheus監(jiān)控Redis指標(biāo),以及常見的Redis指標(biāo)和告警規(guī)則,需要的朋友可以參考下2025-02-02ubuntu 16.04安裝redis的兩種方式教程詳解(apt和編譯方式)
這篇文章主要介紹了ubuntu 16.04安裝redis的兩種方式教程詳解(apt和編譯方式),需要的朋友可以參考下2018-03-03基于 Redis 的 JWT令牌失效處理方案(實現(xiàn)步驟)
當(dāng)用戶登錄狀態(tài)到登出狀態(tài)時,對應(yīng)的JWT的令牌需要設(shè)置為失效狀態(tài),這時可以使用基于Redis 的黑名單方案來實現(xiàn)JWT令牌失效,本文給大家分享基于 Redis 的 JWT令牌失效處理方案,感興趣的朋友一起看看吧2024-03-03Redis遍歷所有key的兩個命令(KEYS 和 SCAN)
這篇文章主要介紹了Redis遍歷所有key的兩個命令(KEYS 和 SCAN),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-04-04Redis中哈希結(jié)構(gòu)(Dict)的實現(xiàn)
本文主要介紹了Redis中哈希結(jié)構(gòu)(Dict)的實現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-06-06