空間與時間
空間換時間是在數(shù)據(jù)庫中經(jīng)常出現(xiàn)的術(shù)語,簡單說就是把查詢需要的條件進行索引的存儲,然后查詢時為O(1)的時間復(fù)雜度來快速獲取數(shù)據(jù),從而達到了使用空間存儲來換快速的時間響應(yīng)!對于redis這個k/v存儲系統(tǒng)來說,復(fù)雜的查詢不是它所建議的,它的優(yōu)勢在于通過key快速定位數(shù)據(jù),它定位數(shù)據(jù)的速度與數(shù)據(jù)多少沒有直接關(guān)系,無論是1萬還是1億數(shù)據(jù),它定位的時間復(fù)雜度都是O(1),而在實際使用中,可能不簡單使用key定位數(shù)據(jù)就夠了,可能還需要數(shù)據(jù)里的某個屬性去定位數(shù)據(jù),這種情況第一感覺不能用redis,或者說,不能用k/v存儲系統(tǒng)了,但這不是我們應(yīng)該說的,我們要的是解決方案,換個角度去思考,我們是否可以把那個屬性拿出來當(dāng)新的key,把原來的key當(dāng)作它的value呢,答案是肯定的,這就是用空間到換時間,只需要兩個查詢就可以搞定了!
上面是一個100萬的hash集合,key是用戶id,value是一個用戶實體,我們通過RedisClient.RedisManager.Instance.GetDatabase().HashGet("VoteList", id)很方便的可以拿到對應(yīng)的用戶實體!
我希望通過用戶名拿到用戶實體?
這種需求,我們不要直接解決,如果直接解決,那唯一的辦法就是遍歷所有數(shù)據(jù),然后一一對比,時間復(fù)雜度就是O(N),太可怕了!
延伸閱讀
- ssh框架 2016-09-30
- 阿里移動安全 [無線安全]玩轉(zhuǎn)無線電——不安全的藍牙鎖 2017-07-26
- 消息隊列NetMQ 原理分析4-Socket、Session、Option和Pipe 2024-03-26
- Selective Search for Object Recognition 論文筆記【圖片目標(biāo)分割】 2017-07-26
- 詞向量-LRWE模型-更好地識別反義詞同義詞 2017-07-26
- 從棧不平衡問題 理解 calling convention 2017-07-26
- php imagemagick 處理 圖片剪切、壓縮、合并、插入文本、背景色透明 2017-07-26
- Swift實現(xiàn)JSON轉(zhuǎn)Model - HandyJSON使用講解 2017-07-26
- 阿里移動安全 Android端惡意鎖屏勒索應(yīng)用分析 2017-07-26
- 集合結(jié)合數(shù)據(jù)結(jié)構(gòu)來看看(二) 2017-07-26