欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Redis的Hash類型及相關(guān)命令小結(jié)

 更新時(shí)間:2025年01月07日 08:29:08   作者:新綠MEHO  
edis Hash是一種數(shù)據(jù)結(jié)構(gòu),用于存儲(chǔ)字段和值的映射關(guān)系,本文就來(lái)介紹一下Redis的Hash類型及相關(guān)命令小結(jié),具有一定的參考價(jià)值,感興趣的可以了解一下

HSET

設(shè)置 hash 中指定的字段(field)的值(value)。

語(yǔ)法

HSET key field value [field value ...]

時(shí)間復(fù)雜度:插??組 field 為 O(1), 插? N 組 field 為 O(N)
返回值:添加的字段的個(gè)數(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 中指定字段的值。

語(yǔ)法

HGET key field

時(shí)間復(fù)雜度:O(1)
返回值:字段對(duì)應(yīng)的值或者 nil。

舉例

redis> HSET myhash field1 "foo"
(integer) 1
redis> HGET myhash field1
"foo"
redis> HGET myhash field2
(nil)

HEXISTS

判斷 hash 中是否有指定的字段。

語(yǔ)法

HEXISTS key field

時(shí)間復(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 中指定的字段。

語(yǔ)法

HDEL key field [field ...]

時(shí)間復(fù)雜度:刪除?個(gè)元素為 O(1). 刪除 N 個(gè)元素為 O(N).
返回值:本次操作刪除的字段個(gè)數(shù)。

舉例

redis> HSET myhash field1 "foo"
(integer) 1
redis> HDEL myhash field1
(integer) 1
redis> HDEL myhash field2
(integer) 0

HKEYS

獲取 hash 中的所有字段。

語(yǔ)法

HKEYS key

時(shí)間復(fù)雜度:O(N), N 為 field 的個(gè)數(shù).
返回值:字段列表。

舉例

redis> HSET myhash field1 "Hello"
(integer) 1
redis> HSET myhash field2 "World"
(integer) 1
redis> HKEYS myhash
1) "field1"
2) "field2"

HVALS

獲取 hash 中的所有的值。

語(yǔ)法

HVALS key

時(shí)間復(fù)雜度:O(N), N 為 field 的個(gè)數(shù).
返回值:所有的值。

舉例

redis> HSET myhash field1 "Hello"
(integer) 1
redis> HSET myhash field2 "World"
(integer) 1
redis> HVALS myhash
1) "Hello"
2) "World"

HGETALL

獲取 hash 中的所有字段以及對(duì)應(yīng)的值。

語(yǔ)法

HGETALL key

時(shí)間復(fù)雜度:O(N), N 為 field 的個(gè)數(shù).
返回值:字段和對(duì)應(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 中多個(gè)字段的值。

語(yǔ)法

HMGET key field [field ...]

時(shí)間復(fù)雜度:只查詢?個(gè)元素為 O(1), 查詢多個(gè)元素為 O(N), N 為查詢?cè)貍€(gè)數(shù).
返回值:字段對(duì)應(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 中的所有字段的個(gè)數(shù)。

語(yǔ)法

HLEN key

時(shí)間復(fù)雜度:O(1)

返回值:字段個(gè)數(shù)。

舉例

redis> HSET myhash field1 "Hello"
(integer) 1
redis> HSET myhash field2 "World"
(integer) 1
redis> HLEN myhash
(integer) 2

HSETNX

在字段不存在的情況下,設(shè)置 hash 中的字段和值。

語(yǔ)法

HSETNX key field value

時(shí)間復(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 中字段對(duì)應(yīng)的數(shù)值添加指定的值。

語(yǔ)法

HINCRBY key field increment

時(shí)間復(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 的浮點(diǎn)數(shù)版本。

語(yǔ)法

HINCRBYFLOAT key field increment

時(shí)間復(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)哈希類型元素個(gè)數(shù)?于 hash-max-ziplist-entries 配置(默認(rèn) 512 個(gè))、同時(shí)所有值都?于 hash-max-ziplist-value 配置(默認(rèn) 64 字節(jié))時(shí),Redis 會(huì)使? ziplist 作為哈希的內(nèi)部實(shí)現(xiàn),ziplist 使?更加緊湊的結(jié)構(gòu)實(shí)現(xiàn)多個(gè)元素的連續(xù)存儲(chǔ),所以在節(jié)省內(nèi)存???hashtable 更加優(yōu)秀。
hashtable(哈希表):當(dāng)哈希類型?法滿? ziplist 的條件時(shí),Redis 會(huì)使? hashtable 作為哈希的內(nèi)部實(shí)現(xiàn),因?yàn)榇藭r(shí) ziplist 的讀寫效率會(huì)下降,? hashtable 的讀寫時(shí)間復(fù)雜度為 O(1)。

下?的?例演?了哈希類型的內(nèi)部編碼,以及響應(yīng)的變化。

1)當(dāng) field 個(gè)數(shù)?較少且沒(méi)有?的 value 時(shí),內(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é)時(shí),內(nèi)部編碼會(huì)轉(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 個(gè)數(shù)超過(guò) 512 時(shí),內(nèi)部編碼也會(huì)轉(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)用場(chǎng)景

1.緩存數(shù)據(jù)

類似于String類型,Hash類型也可以用于緩存數(shù)據(jù)。不過(guò),由于Hash類型可以存儲(chǔ)多個(gè)字段和字段值,因此更適合用于緩存具有多個(gè)屬性的數(shù)據(jù)。
例如,可以將經(jīng)常訪問(wèn)的商品信息、用戶信息等緩存在Hash類型中,以便快速讀取和響應(yīng)客戶端請(qǐng)求。

2.對(duì)象屬性存儲(chǔ)

Hash類型非常適合存儲(chǔ)對(duì)象的各個(gè)屬性,如用戶信息、商品信息等。可以將對(duì)象類別和ID構(gòu)成鍵名,使用字段表示對(duì)象的屬性,而字段值則存儲(chǔ)屬性值。例如,要存儲(chǔ)ID為1的汽車對(duì)象,可以分別使用名為color、name和price的字段來(lái)存儲(chǔ)該輛汽車的顏色、名稱和價(jià)格。
同樣,對(duì)于用戶信息,可以將用戶的ID作為Hash類型的鍵,用戶的各種屬性(如用戶名、年齡、性別等)作為字段和字段值進(jìn)行存儲(chǔ)。

到此這篇關(guān)于Redis的Hash類型及相關(guān)命令小結(jié)的文章就介紹到這了,更多相關(guān)Redis Hash類型內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家! 

相關(guān)文章

  • 解決linux下redis數(shù)據(jù)庫(kù)overcommit_memory問(wèn)題

    解決linux下redis數(shù)據(jù)庫(kù)overcommit_memory問(wèn)題

    這篇文章介紹了解決linux下redis數(shù)據(jù)庫(kù)overcommit_memory問(wèn)題的方法,對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2022-02-02
  • Redis分布式限流組件設(shè)計(jì)與使用實(shí)例

    Redis分布式限流組件設(shè)計(jì)與使用實(shí)例

    本文主要講解基于 自定義注解+Aop+反射+Redis+Lua表達(dá)式 實(shí)現(xiàn)的限流設(shè)計(jì)方案。實(shí)現(xiàn)的限流設(shè)計(jì)與實(shí)際使用。具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-08-08
  • Redis和MySQL保證雙寫一致性的問(wèn)題解析

    Redis和MySQL保證雙寫一致性的問(wèn)題解析

    Redis和MySQL的雙寫一致性指的是在同時(shí)使用緩存和數(shù)據(jù)庫(kù)存儲(chǔ)數(shù)據(jù)的時(shí)候,保證Redis和MySQL中數(shù)據(jù)的一致性,那么如何才能保證他們的一致性呢,下面小編就來(lái)為大家詳細(xì)講講
    2023-11-11
  • Redis如何安裝部署(單節(jié)點(diǎn))

    Redis如何安裝部署(單節(jié)點(diǎn))

    這篇文章主要介紹了Redis如何安裝部署(單節(jié)點(diǎn))問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-01-01
  • 通過(guò)prometheus監(jiān)控redis實(shí)時(shí)運(yùn)行狀態(tài)的操作方法

    通過(guò)prometheus監(jiān)控redis實(shí)時(shí)運(yùn)行狀態(tài)的操作方法

    本文詳細(xì)介紹了如何通過(guò)Prometheus監(jiān)控Redis的運(yùn)行狀態(tài),包括安裝配置Redis、Redis Exporter以及Prometheus,配置Prometheus監(jiān)控Redis指標(biāo),以及常見(jiàn)的Redis指標(biāo)和告警規(guī)則,需要的朋友可以參考下
    2025-02-02
  • ubuntu 16.04安裝redis的兩種方式教程詳解(apt和編譯方式)

    ubuntu 16.04安裝redis的兩種方式教程詳解(apt和編譯方式)

    這篇文章主要介紹了ubuntu 16.04安裝redis的兩種方式教程詳解(apt和編譯方式),需要的朋友可以參考下
    2018-03-03
  • 基于 Redis 的 JWT令牌失效處理方案(實(shí)現(xiàn)步驟)

    基于 Redis 的 JWT令牌失效處理方案(實(shí)現(xiàn)步驟)

    當(dāng)用戶登錄狀態(tài)到登出狀態(tài)時(shí),對(duì)應(yīng)的JWT的令牌需要設(shè)置為失效狀態(tài),這時(shí)可以使用基于Redis 的黑名單方案來(lái)實(shí)現(xiàn)JWT令牌失效,本文給大家分享基于 Redis 的 JWT令牌失效處理方案,感興趣的朋友一起看看吧
    2024-03-03
  • Redis遍歷所有key的兩個(gè)命令(KEYS 和 SCAN)

    Redis遍歷所有key的兩個(gè)命令(KEYS 和 SCAN)

    這篇文章主要介紹了Redis遍歷所有key的兩個(gè)命令(KEYS 和 SCAN),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2021-04-04
  • Redis中哈希結(jié)構(gòu)(Dict)的實(shí)現(xiàn)

    Redis中哈希結(jié)構(gòu)(Dict)的實(shí)現(xiàn)

    本文主要介紹了Redis中哈希結(jié)構(gòu)(Dict)的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-06-06
  • Ubuntu下Redis密碼設(shè)置問(wèn)題及其解決過(guò)程

    Ubuntu下Redis密碼設(shè)置問(wèn)題及其解決過(guò)程

    這篇文章主要介紹了Ubuntu下Redis密碼設(shè)置問(wèn)題及其解決過(guò)程,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-06-06

最新評(píng)論