您好,登錄后才能下訂單哦!
哈希表(HashTable)是一種數據結構,它實現了“鍵-值”(Key-Value)的映射。根據Key就能快速找到Value 。并且,無論有多少個鍵值對,查詢時間始終不變。Python的字典就是基于哈希表實現的。
????在Redis中也有一個數據結構叫作哈希表。
????在Redis中,使用哈希表可以保存大量數據,且無論有多少數據,查詢時間始終保持不變。
????Redis的一個哈希表里面可以儲存2的32次方減1(約等于43億)個鍵值對。
現在, 一些論壇網站能夠顯示用戶當前是在線狀態還是離線狀態。那這個功能是怎么實現的呢?其中一種實現方法就是基于Redis來實現
????程序的邏輯非常簡單,包括以下幾個步驟:
????????(1).用戶登錄時,在Redis中添加一個字符串, Key為用戶賬號, Value為1 。
????????(2).用戶退出網站時,從Redis中刪除賬號名對應的Key 。
????????(3).查詢時,程序嘗試從Redis中獲取用戶賬號對應的字符串:如果值為1 ,則表示“在線";如果值為None,則表示“不在線”。
分別使用字符串和哈希表記錄用戶的在線信息, 井比較在這個場景下哈希表相對于字符串有什么優勢?
????如果有1000個用戶同時在線,則Redis列出所有Key后的結果如圖:
????????
????現在,網站又加入了一個積分機制。每個用戶都有一個積分數據,由于這個數據需要經常查詢和修改,因此也使用Redis來保存
????那問題來了, 在線信息使用用戶賬號作為Key, 積分信息也使用賬號作為Key,這不就沖突了嗎?
????于是有人給不同的Key加上了后綴。例如,記錄用戶是否在線,使用的Key為“賬號:online”。如果用戶賬號為10032,那他的在線狀態Key就是“10032:online” 。記錄用戶積分的Key為“賬號:score”,例如用戶10032對應的積分Key為“10032:score”
????注意:在Redis中, Key 中的冒號就是普通的字符,用來分割前綴和后綴,沒有什么特殊意義。寫成“10032_online”或者“10032-score”效果完全一樣
????使用hash存儲的代碼示例:
????????
????????
??? ????? 第12行代碼:向Redis中名為user_online_status的哈希表中添加一個字段, 字段名為用戶賬號,值為l 。如果不存在名為user_online_status的哈希表, 則自動創建一個。
????????? 第21行代碼:從Redis中名為user online status 的晗希表中刪除一個字段,宇段名為用戶賬號。
????????? 第30行代碼:檢查名為user_online_status的哈希表中是否有某個特定的宇段, 如果沒有這個字段就返回False,如果有這個字段就返回True。
????????
????使用晗希表不僅可以減少Redis 的個數, 還能優化儲存空間。Red is 官方就特別說明,哈希表對存儲結構進行過特殊的優化,儲存相同的內容,占用的內存比字符串要小很多。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。