Redis - 基礎數據類型

来源:https://www.cnblogs.com/fatedeity/archive/2023/03/22/17242402.html
-Advertisement-
Play Games

學會使用 Redis 的一個重要內容就是 Redis 的數據類型,對於開發人員而言,學會 Redis 基礎數據類型的使用即可應用到程式開發當中。 ...


簡介

根據 官網文檔 的解釋,可以瞭解 Redis 基礎數據類型的一些基本信息:

Redis 基礎數據類型

對於 Redis 來說,存儲的 key 值都是字元串類型,討論數據類型的時候,指的都是存儲的 value 值。這裡主要是包括 5 種數據類型:String、List、Set、Hash、SortedSet。

如果想要瞭解 Redis 基礎數據類型支持的命令,可以查看 官方文檔,篩選對應數據類型即可。

String

String 是最基本的 Redis 數據類型,其是二進位安全的,這表示 String 可以存儲任何類型的數據,如字元串、數字、圖片、序列化對象等等。

官方文檔 提供了部分對 String 數據類型的說明,具體 String 數據類型支持的命令也可以通過訪問 這裡 查看。

有一點需要註意,String 數據類型最高支持存儲 512MB 長度的數據。

通常情況,String 數據類型會使用在以下場景:

  • 數據緩存:直接存儲字元串、序列化數據、圖片、視頻等數據
  • 計數器:使用 INCRBY 這樣的增量命令實現原子計數器
  • 分散式鎖:使用多參數的 SET 命令實現分散式鎖

List

Redis 的 List 數據類型是一個雙端鏈表,因此 List 隨機存取的效率比較低,不過可以像使用鏈表一樣實現鏈式棧、鏈式隊列等功能。

官方文檔 提供了部分對 List 數據類型的說明,具體 List 數據類型支持的命令也可以通過訪問 這裡 查看。

有一點需要註意,List 數據類型最大支持存儲 \(2^{32} - 1\)(約 42 億) 個元素。

通常情況,List 數據類型會使用在以下場景:

  • 棧:聯合使用 LPUSH 命令和 LPOP 命令即可實現棧
  • 隊列:聯合使用 LPUSH 命令和 RPOP 命令即可實現隊列
  • 有限集合:聯合使用 LPUSH 命令和 LTRIM 命令即可實現有限集合
  • 消息隊列:聯合使用 LPUSH 命令和 BRPOP 命令即可實現延時消息隊列

Set

Set 是一個無序不重覆集合,並且現有命令實現集合的交集、並集、差集等功能,但頻繁使用這些功能會影響 Redis 伺服器的性能,建議謹慎使用。

官方文檔 提供了部分對 Set 數據類型的說明,具體 Set 數據類型支持的命令也可以通過訪問 這裡 查看。

同 List 數據類型一樣,Set 數據類型最大支持存儲 \(2^{32} - 1\)(約 42 億) 個元素。

通常情況,Set 數據類型會使用在以下場景:

  • 標簽:不同的標簽存儲在不同集合中,既可以查詢是否存在相同標簽,也可以聚合不同標簽
  • 共同好友:不同用戶的好友存儲在不同集合中,使用交集可以得到共同好友
  • 獨立 IP:利用 Set 的元素唯一性,可以快速實時統計網站的獨立 IP

Hash

Redis 的 Hash 數據類型存儲著字元串 field 和字元串 value 的映射關係,特別適合存儲 key-value 結構。

官方文檔 提供了部分對 Hash 數據類型的說明,具體 Hash 數據類型支持的命令也可以通過訪問 這裡 查看。

每個 Hash 數據類型最多可以存儲 \(2^{32} - 1\)(約 42 億) 個鍵值對,實際上,Hash 數據類型僅受 Redis 所部署的記憶體限制。

通常情況,Hash 數據類型會使用在以下場景:

  • 數據緩存:對比於存儲 JSON 字元串的 String 類型,Hash 更直觀、更節省空間、更靈活

SortedSet

SortedSet 數據類型有點類似於 Set 數據類型,不同之處在於 SortedSet 數據類型支持按照給定的分數對數據進行排序。

SortedSet 中的集合通過哈希表實現,在實際使用中,添加、刪除、查找的效率都非常高。

官方文檔 提供了部分對 Hash 數據類型的說明,具體 Hash 數據類型支持的命令也可以通過訪問 這裡 查看。

大多數 SortedSet 操作的複雜度是 O(log(N)),其中 N 是成員數。部分批量查詢命令的時間複雜度可以達到 O(log(N) + M),這裡的 M 是返回的結果數。

通常情況,SortedSet 數據類型會使用在以下場景:

  • 排行榜:排行榜需要按照某個規則排序,將這個規則值存儲成分數,即可實現排行榜的功能
  • 權重隊列:通過將任務的權重存儲成分數,工作線程可以按照分數的倒序來獲取工作任務

其他數據類型

Redis 中最常見的數據類型就是 String、List、Set、Hash、SortedSet 這 5 種,也是最初支持的數據類型。

當然,Redis 也有一些不常見、卻適用於特殊場景的數據類型,瞭解這些數據類型也是很必要的。

Stream 是 Redis 5.0 版本新增的數據類型,其本身類似於 append-only 日誌。實際上給 Redis 的發佈、訂閱功能提供了持久化和主備複製功能,可以讓任何客戶端訪問任何時刻的數據,並且能記住每一個客戶端的訪問位置,還能保證消息不丟失。

Geospatial 是 Redis 3.2 版本新增的數據類型,此類型主要用於存儲地理位置信息,並且 Redis 提供了常見的地理位置查詢命令。

HyperLogLog 是 Redis 2.8.9 版本新增的數據類型,主要用於做基數統計的演算法。其使用不超過 12 KB 的存儲,且僅達到 0.81% 的標準錯誤率,應用場景也是十分特殊。

Bitmap 是 String 數據類型的擴展,是定義在 String 數據類型上的面向位的操作,其最大的優點是當存儲信息時可以節省極大的空間。

首發於「程式員翔仔」,點擊查看更多。


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

-Advertisement-
Play Games
更多相關文章
  • MySQL基礎:多表查詢 多表關係 概述 ​ 項目開發中,在進行資料庫表結構設計時,會根據業務需求及模塊之間的關係,分析並設計表結構,由於業務之間相互關聯,所以各個表結構之間也存在著各種聯繫,基本上分為三種: 一對多(多對一) 多對多 一對一 一對多(多對一) 案例:部門與員工的關係 關係:一個部門 ...
  • 資料庫系統概述 一、資料庫基本概念 1 數據 數據(Data)是描述事物的符號記錄,是指用物理符號記錄下來的、可以鑒別的信息。 數據以及關於該數據的解釋是密切相關的。 數據的解釋是對數據含義的說明,也稱為數據的語義,即數據所蘊含的信息。 數據與其語義密不可分,沒有語義的數據是沒有意義和不完整的。 數 ...
  • 資料庫編程 第一節 存儲過程 一、存儲過程的基本概念 存儲過程是一組為了完成某項特定功能的 SQL 語句集,其實質上就是一段存儲在資料庫中的代碼,它可以由聲明式的 SQL 語句(如 CREATE、UPDATE 和 SELECT 等語句)和過程式 SQL 語句(如 IF...THEN...ELSE 控 ...
  • 1、內連接 語法: SELECT 查詢欄位1,查詢欄位2, ... FROM 表1 [INNER] JOIN 表2 ON 表1.關係欄位=表2.關係欄位 準備數據 -- 若存在資料庫mydb則刪除 DROP DATABASE IF EXISTS mydb; -- 創建資料庫mydb CREATE D ...
  • 首發微信公眾號:SQL資料庫運維 原文鏈接:https://mp.weixin.qq.com/s?__biz=MzI1NTQyNzg3MQ==&mid=2247485212&idx=1&sn=450e9e94fa709b5eeff0de371c62072b&chksm=ea37536cdd40da7 ...
  • MySQL基礎:約束 概述 概念:約束是作用於表中欄位上的規則,用於限制存儲在表中的數據。 目的:保證資料庫中的數據的正確、有效和完整性。 分類: | 約束 | 描述 | 關鍵字 | | : : | : : | : : | | 非空約束 | 限制該欄位的數據不能為null | NOT NULL | ...
  • 數字革命悄然爆發,與互聯網互相成就的“人氣王”MySQL開源資料庫,如今也正面臨突破發展瓶頸的關鍵時刻,作為記憶體中的實時數據平臺,虹科提供的Redis企業版資料庫能與MySQL輕鬆實現協同合作,帶領MYSQL跑贏數字時代! ...
  • 身處數字經濟時代,隨著大數據應用越來越廣泛,越來越多的企業和組織開始關註大數據基礎平臺的建設和運營。在認識到其的重要性之後,如何具體著手搭建或採購大數據基礎平臺成為下一步需要解決的問題。 在大數據基礎平臺中,大數據組件是非常重要的一部分,包括數據存儲、數據處理、數據分析、數據可視化等。在選擇大數據組 ...
一周排行
    -Advertisement-
    Play Games
  • 概述:在C#中,++i和i++都是自增運算符,其中++i先增加值再返回,而i++先返回值再增加。應用場景根據需求選擇,首碼適合先增後用,尾碼適合先用後增。詳細示例提供清晰的代碼演示這兩者的操作時機和實際應用。 在C#中,++i 和 i++ 都是自增運算符,但它們在操作上有細微的差異,主要體現在操作的 ...
  • 上次發佈了:Taurus.MVC 性能壓力測試(ap 壓測 和 linux 下wrk 壓測):.NET Core 版本,今天計劃準備壓測一下 .NET 版本,來測試並記錄一下 Taurus.MVC 框架在 .NET 版本的性能,以便後續持續優化改進。 為了方便對比,本文章的電腦環境和測試思路,儘量和... ...
  • .NET WebAPI作為一種構建RESTful服務的強大工具,為開發者提供了便捷的方式來定義、處理HTTP請求並返迴響應。在設計API介面時,正確地接收和解析客戶端發送的數據至關重要。.NET WebAPI提供了一系列特性,如[FromRoute]、[FromQuery]和[FromBody],用 ...
  • 原因:我之所以想做這個項目,是因為在之前查找關於C#/WPF相關資料時,我發現講解圖像濾鏡的資源非常稀缺。此外,我註意到許多現有的開源庫主要基於CPU進行圖像渲染。這種方式在處理大量圖像時,會導致CPU的渲染負擔過重。因此,我將在下文中介紹如何通過GPU渲染來有效實現圖像的各種濾鏡效果。 生成的效果 ...
  • 引言 上一章我們介紹了在xUnit單元測試中用xUnit.DependencyInject來使用依賴註入,上一章我們的Sample.Repository倉儲層有一個批量註入的介面沒有做單元測試,今天用這個示例來演示一下如何用Bogus創建模擬數據 ,和 EFCore 的種子數據生成 Bogus 的優 ...
  • 一、前言 在自己的項目中,涉及到實時心率曲線的繪製,項目上的曲線繪製,一般很難找到能直接用的第三方庫,而且有些還是定製化的功能,所以還是自己繪製比較方便。很多人一聽到自己畫就害怕,感覺很難,今天就分享一個完整的實時心率數據繪製心率曲線圖的例子;之前的博客也分享給DrawingVisual繪製曲線的方 ...
  • 如果你在自定義的 Main 方法中直接使用 App 類並啟動應用程式,但發現 App.xaml 中定義的資源沒有被正確載入,那麼問題可能在於如何正確配置 App.xaml 與你的 App 類的交互。 確保 App.xaml 文件中的 x:Class 屬性正確指向你的 App 類。這樣,當你創建 Ap ...
  • 一:背景 1. 講故事 上個月有個朋友在微信上找到我,說他們的軟體在客戶那邊隔幾天就要崩潰一次,一直都沒有找到原因,讓我幫忙看下怎麼回事,確實工控類的軟體環境複雜難搞,朋友手上有一個崩潰的dump,剛好丟給我來分析一下。 二:WinDbg分析 1. 程式為什麼會崩潰 windbg 有一個厲害之處在於 ...
  • 前言 .NET生態中有許多依賴註入容器。在大多數情況下,微軟提供的內置容器在易用性和性能方面都非常優秀。外加ASP.NET Core預設使用內置容器,使用很方便。 但是筆者在使用中一直有一個頭疼的問題:服務工廠無法提供請求的服務類型相關的信息。這在一般情況下並沒有影響,但是內置容器支持註冊開放泛型服 ...
  • 一、前言 在項目開發過程中,DataGrid是經常使用到的一個數據展示控制項,而通常表格的最後一列是作為操作列存在,比如會有編輯、刪除等功能按鈕。但WPF的原始DataGrid中,預設只支持固定左側列,這跟大家習慣性操作列放最後不符,今天就來介紹一種簡單的方式實現固定右側列。(這裡的實現方式參考的大佬 ...