這篇文章帶大家了解redis中的hash資料類型,介紹一下hash 類型資料的基本操作,希望對大家有幫助!
我們先來看這個範例
在上一節我們一起了解了string 儲存類型。但是如果是物件資料的儲存具有較頻繁的更新需求,操作會顯得笨重。例如:user:id:100 -> {"id":100,"name":"春晚","fans":12355,"blogs":99,"focus:83}
,如果需要更新一個物件中的局部數據,就需要替換掉所有數據,於是有了以下的需求。【相關推薦:Redis影片教學】
新的需求:對一系列儲存的資料進行編組,方便管理,例如儲存一個物件的資訊所需的儲存結構:一個儲存空間保存多個鍵值對資料
如下圖:
為了解決這個問題,我們引入新的資料類型:hash
。同時hash 儲存結構也做了以下優化
hset key field value
# 查询单个字段数据 hget key field # 查询所有数据 hgetall key
hdel key field1 [field2]
hmset key field1 value1 field2 value2
hmget key field1 field2
hlen key
hexists key field
hkey key hvals key
hincrby key field increment hincrbyfloat key field increment
hash 類型資料操作注意事項
hash 類型下的value 只能儲存字串,不允許儲存其他資料類型,不存在嵌套對象。如果資料未取得到,對應的結果為(nil);
每個hash 可以儲存2 的32 次方減1 個鍵值對;
hash 類型十分貼近物件的資料儲存形式,並且可以靈活添加刪除物件屬性,但hash 設計初衷不是為了儲存大量物件而設計,切記不可濫用,更不可以將hash 作為物件清單使用;
hgetall 操作可以取得全部屬性,如果內部field 過多,遍歷整個資料效率會很低,有可能成為資料存取瓶頸。
概述
##這裡我們不討論購物車與資料庫間的持久化同步,也不討論購物車與訂單之間的關係,同時忽略未登入使用者購物車資訊儲存。我們僅使用redis 的儲存模型來對購物車的條目進行
新增、瀏覽、變更數量、刪除、清空實作方案
# 001 用户购买 ID为101商品 100件,ID为102的商品 200件 hmset 001 101 100 102 200 # 002 用户购买 ID为102商品 1件,ID为104的商品 7件 hmset 002 102 1 104 7
# 001 用户 购买 ID为101的商品 2件,商品的信息为:{"name":"good name"} hmset 001 101:num 2 101:info "{\"name\":\"goods name\"}" # 002 用户 购买 ID为101的商品 1件,商品的信息为:{"name":"good name"} hmset 002 101:num 1 101:info "{\"name\":\"goods name\"}"
在上面的
101:info 對應的值中,字串包含了空格,所以用雙引號引用起來,達到轉義的目的。 商品資訊獨立保存
由於 field2 可能在多個商品記錄中存在,因此 field2 裡的資料可保存到獨立的 hash。此時,如果每增加一條購物車記錄,就保存一次 hash 數據,顯然是不合理的,可以透過
hsetnx
hsetnx key field value
# 将id为101 的商品独立存起来 hsetnx info 101 "{\"name\":\"goods name\"}"
案例:双 11 活动日,销售手机充值卡的商家对移动、联通、电信的 30 元、50 元、100 元商品推出抢购活动,每种商品的抢购上限为 100。
解决方案
实现过程
商品初始信息
# p01商家下,c30充值券1000张,c50充值券1000张,c100充值券1000张 hmset p01 c30 1000 c50 1000 c100 1000
当 c30 售出1件时,值减 1; 当 c100 售出 20 件时,值减 20,如下代码
# p01商家,商品c30售出1件 hincrby p01 c30 -1 # p01商家,商品c100售出20件 hincrby p01 c100 -20
string 存储 json 字符串:读取方便,在更新的时候会整体进行更新
hash 存对象具体的字段:更新灵活
引入 hash 数据类型之后,我们就解决了 string 存储对象,更新对象时需要整体更新的问题。
更多编程相关知识,请访问:编程入门!!
以上是聊聊redis中的hash資料類型,如何操作?的詳細內容。更多資訊請關注PHP中文網其他相關文章!