Redis學習筆記~關於空間換時間的查詢案例

来源:http://www.cnblogs.com/lori/archive/2016/11/11/6053389.html
-Advertisement-
Play Games

回到目錄 空間與時間 空間換時間是在資料庫中經常出現的術語,簡單說就是把查詢需要的條件進行索引的存儲,然後查詢時為O(1)的時間複雜度來快速獲取數據,從而達到了使用空間存儲來換快速的時間響應!對於redis這個k/v存儲系統來說,複雜的查詢不是它所建議的,它的優勢在於通過key快速定位數據,它定位數 ...


回到目錄

空間與時間

空間換時間是在資料庫中經常出現的術語,簡單說就是把查詢需要的條件進行索引的存儲,然後查詢時為O(1)的時間複雜度來快速獲取數據,從而達到了使用空間存儲來換快速的時間響應!對於redis這個k/v存儲系統來說,複雜的查詢不是它所建議的,它的優勢在於通過key快速定位數據,它定位數據的速度與數據多少沒有直接關係,無論是1萬還是1億數據,它定位的時間複雜度都是O(1),而在實際使用中,可能不簡單使用key定位數據就夠了,可能還需要數據里的某個屬性去定位數據,這種情況第一感覺不能用redis,或者說,不能用k/v存儲系統了,但這不是我們應該說的,我們要的是解決方案,換個角度去思考,我們是否可以把那個屬性拿出來當新的key,把原來的key當作它的value呢,答案是肯定的,這就是用空間到換時間,只需要兩個查詢就可以搞定了!

上面是一個100萬的hash集合,key是用戶id,value是一個用戶實體,我們通過RedisClient.RedisManager.Instance.GetDatabase().HashGet("VoteList", id)很方便的可以拿到對應的用戶實體!

我希望通過用戶名拿到用戶實體?

這種需求,我們不要直接解決,如果直接解決,那唯一的辦法就是遍歷所有數據,然後一一對比,時間複雜度就是O(N),太可怕了!

通過添加新的k/v,解決這個問題,這類似於關係資料庫里的全表掃描+索引技術!

實現程式:先通過userName找到UserId,再通過UserId找到用戶實體!

       [TestMethod]
        public void FindBigData()
        {
            Stopwatch sw = new Stopwatch();
            sw.Start();
            var name = RedisClient.RedisManager.Instance.GetDatabase().HashGet("VoteList_UserName", "zzl15");//找到用戶ID
            if (name.HasValue)
            {
                var val = RedisClient.RedisManager.Instance.GetDatabase().HashGet("VoteList", name);//找到用戶實體
                Console.WriteLine("name={0},value={1}", name, val);
            }
            else
            {
                Console.WriteLine("沒有發現這個Key");
            }
            sw.Stop();
            Console.WriteLine("查詢需要的時間:" + sw.ElapsedMilliseconds + "ms");
        }

通過這個實例讓我們知道,做成一件事,可能一步不行,但多幾步一定可以實現!

回到目錄


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • info 伺服器基本信息 monitor 實時轉儲收到的請求 flushdb 清空當前資料庫 flushall 清空所有資料庫 quit 關閉連接 save 將數據同步保持到磁碟 bgsave 非同步 lastsave 返回最後一次成功保存數據到磁碟的時間戳 shundown 將數據同步保持到磁碟並關 ...
  • AND 和 OR 運算符用於基於一個以上的條件對記錄進行過濾。 AND 和 OR 運算符用於基於一個以上的條件對記錄進行過濾。 AND 和 OR 運算符 AND 和 OR 可在 WHERE 子語句中把兩個或多個條件結合起來。 如果第一個條件和第二個條件都成立,則 AND 運算符顯示一條記錄。 如果第 ...
  • 在SQL Server中,為Partition Scheme多次指定Next Used,不會出錯,最後一次指定的FileGroup是Partition Scheme的Next Used,建議,在執行Partition Split操作之前,都要為Partition Scheme指定Next Used。 ...
  • Kafka簡介 轉載請註明出處: "http://www.cnblogs.com/BYRans/" Apache Kafka發源於LinkedIn,於2011年成為Apache的孵化項目,隨後於2012年成為Apache的主要項目之一。Kafka使用Scala和Java進行編寫。Apache Kaf ...
  • 在關係型 DB中,分區表經常使用DateKey(int 數據類型)作為Partition Column,每個月的數據填充到同一個Partition中,由於在Fore-End呈現的報表大多數是基於Month的查詢,按照Month分區的設計能夠提高查詢性能,但是,如果,前任DBA沒有創建Schedule ...
  • 在一測試伺服器(CentOS Linux release 7.2.1511)上安裝MySQL 5.6(5.6.19 MySQL Community Server)時遇到下麵錯誤,這個是因為CentOS 7的預設資料庫已經不再是MySQL了,而是MariaDB. MySQL安裝時的mysql lib庫... ...
  • Kafka Consumer 通過之前的架構介紹,對Consumer有了一個初步的瞭解。這裡再深入一點來瞭解一下Consumer。 1、Consumer Group與Topic訂閱 1.1 Consumer與partition 1.2 Consumer與Consumer Group 1.3 Coor ...
  • 第一步:打開sql service 找到 SQL SERVER Agent 下的 jobs 如圖: 註:如果沒有找到,請查看你安裝sql service 的版本 通過 select @@VERSION查看 本人安裝版本為:Microsoft SQL Server 2014 - 12.0.4100.1 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...