Redis基礎類型常用操作命令

来源:https://www.cnblogs.com/awayfly/archive/2019/11/26/11934328.html
-Advertisement-
Play Games

Redis基礎類型常用操作命令 概念:Redis是用C語言開發的一個開源的高性能鍵值對資料庫。 特征: 數據間沒有必然的聯繫 內部採用單線程機制進行工作 高性能 多數據類型支持 1. 字元串類型 String 2. 列表類型 List 3. 散列類型 Map 4. 集合類型 Set 5. 有序集合類 ...


Redis基礎類型常用操作命令

概念:Redis是用C語言開發的一個開源的高性能鍵值對資料庫。

特征:

  • 數據間沒有必然的聯繫
  • 內部採用單線程機制進行工作
  • 高性能
  • 多數據類型支持
    1. 字元串類型 String
    2. 列表類型 List
    3. 散列類型 Map
    4. 集合類型 Set
    5. 有序集合類型 SortedSet
  • 持久化支持

應用場景

  • 為熱點數據加速查詢;如:熱點商品、熱點新聞、熱點資訊等高訪問量信息。
  • 任務隊列;如:秒殺、搶購、購票等。
  • 即時信息查詢;如:排行榜等。
  • 時效性信息控制;如:驗證碼、投票控制等。
  • 分散式數據共用;如:分散式架構中的session等。
  • 消息隊列
  • 分散式鎖

基礎數據類型之: String

單個string類型的存儲空間為512MB

string基本操作

  • 添加或修改數據

    set key value
  • 獲取數據

    get key
  • 刪除數據

    del key
  • 設置過期時間(預設單位為秒)

    expire key second
  • 追加信息到初始value後邊

    append key value
  • 添加/修改多個數據

    mset key1 value1 key2 value2...
  • 獲取多個數據

    mget key1 key2 ...
  • 獲取字元串長度

    strlen key
  • 設置key的生命周期 控制生命周期

    setex key seconds value           (秒)
    psetex key millisexxonds value     (毫秒)
  • key的設置約定

    與資料庫中的表-主鍵-欄位一一對應

    表名 主鍵名 主鍵值 欄位名
    eg1 order id 443523454 name
    eg2 equire id 435432543 type
    eg3 news id 45435454 title

基礎數據類型之:Hash

  • 存儲需求: 對一系列存儲的數據進行編排,方便管理,典型應用存儲對象信息
  • 存儲結構:一個存儲空間存儲多個鍵值對數據
  • hash類型:底層使用哈希表結構實現數據存儲

redis hash存儲空間

hash存儲結構優化

  • 如果field數量較少,存儲結構優化為類數組結構
  • 如果field數量較多,存儲結構使用HashMap結構

hash類型基本操作

  • 添加/修改數據

    hset key field value
  • 獲取數據

    hget key field 
    hgetall key
  • 刪除數據

    hdel key field [field2 ...]
  • 添加或刪除多個數據

    hmset key field1 value1 field2 value2 ...
  • 獲取多個數據

    hmget key field1 field2 ...
  • 獲取hash表中的欄位的數量

    hlen key
  • 獲取hash表中是否存在指定的欄位

    hexists key field
  • 獲取哈希表中所用的欄位名或欄位值

    hkeys key
    hvalues key
  • 設置指定欄位的數值數據增加指定範圍的值

    hincrby key field increment
    hincrbyfloat key field increment
  • 如果key值下的field存在則不做操作 不存在則添加進去

    hsetnx key field value

hash類型數據操作的註意事項

  • hash類型下的value只能存儲字元串,不允許存儲其他數據類型,不存在嵌套現象,如果數據未獲取到,對應的值為(nil)

  • 每個hash存儲的鍵值對上限為
    $$
    2^{32}-1
    $$
    個鍵值對

  • hash類型十分貼近對象的存儲形式,並且可以靈活刪除對象屬性。但hash設計初衷並不是為了存儲大量對象而設計的,切記不可濫用,更不可將hash作為對象列表使用

  • hgetall操作可以獲取全部屬性,如果內部field過多,遍歷整體數據效率會很低,有可能會成為數據訪問瓶頸

應用場景

  • 電商網站購物車設計實現

基礎數據類型之:list

  • 數據存儲需求:存儲多個數據,並對數據進入存儲Jon關鍵的順序進行區分
  • 需要的存儲結構:一個存儲空間存儲多個數據,並且數據可以體現進入順序
  • list類型:保存多個數據,底層使用雙向鏈表存儲結構實現

list類型存儲空間

list類型是雙向鏈表存儲的

list基本操作

  • 添加/修改數據

    lpush key value1 value2 [value3] ...   //從list鏈表左側添加
    rpush key value1 value2 [value3] ...   //從list右側添加
  • 獲取數據

    lrange key start stop       //指定鏈表起始結束位置中的value
    //在獲取未知長的的list類型的時候,想查看所有的value可以使用   -1表示倒數第一個    lrange key start -1
    lindex key index            //獲取鏈表中指定位置的值
    llen key                    //獲取鏈表的長度
  • 獲取並移除數據

    lpop key
    rpop key
  • 規定時間內獲取並移除數據(阻塞式數據獲取)

    blpop key1 [key2] timeout        //指定時間內取出並移除key值對應的value,若timeout超時仍未取出則返回空值(nil)   若本來沒有   其他客戶端在等待的時候添加了這個key的value則做操作    任務隊列
    brpop key1 [key2] timeout
  • 移除指定數據

    lrem key count value

list類型數據操作註意事項

  • list中保存的數據都是string類型的,數據總容量有限最多 2^32-1個元素
  • list具有索引概念,但操作數據時通常以隊列的形式進行入隊出隊操作,或以棧的形式進行入棧出棧操作
  • 獲取全部操作結束數據的索引設置為-1
  • list可以對數據進行分頁操作,通常第一頁的信息來自list,第二頁及更多的數據信息通過資料庫進行查詢載入

基礎數據類型之:set

  • 存儲需求:存儲大量的數據,在查詢方面提供更高的效率
  • 存儲結構:能夠保存大量的數據,高效的內部存儲機制,便於查詢
  • set類型:與hash存儲結構完全相同,僅存儲鍵,不存儲值(nil),並且值不允許為空

redis基礎學習 set類型存儲空間

set存儲結構是string類型的無序集合,內部存儲時hash存儲結構,因此添加、查找、刪除的複雜度都是O(1)

set基本操作

  • 添加不重覆的數據

    sadd key value
  • 獲取存儲的所有數據

    smembers key
  • 刪除數據

    strem key member1 [member2]
  • 獲取集合數據總量

    scard key
  • 判斷集合中是否包含指定數據

    sismember key member
  • 隨機獲取集合中指定數量的數據

    srandmember key [count]
  • 隨機獲取集合中某個數據並將該數據移出集合

    apop key
  • 兩個集合的交、並、差集

    sinter key1 [key2]
    sunion key1 [key2]
    adiff key1 [key2]
  • 求兩個集合的交、並、差集並存儲到指定集合中

    sinterstore destination key1 [key2]
    sunionstore destination key1 [key2]
    sdiffstore destination key1 [key2]
  • 將指定數據從原始集合中移動到目標集合中

    smove source destination member

註意事項

  • set類型不允許有重覆數據,如果添加的數據在set中已存在,將只保留一份

  • set雖然與hash存儲結構相同,但無法啟用hash中存儲值的空間

基礎數據類型:sortedSet

  • 存儲需求:數據排序有利於數據的展示效果,需要提供一種可以根據自身特征進行排序的方式

  • 存儲結構:可以保存排序的數據

  • 存儲類型:在set的存儲結構上添加可排序欄位

基本操作

  • 添加數據

    zadd key scorel member [score2 member2]
  • 獲取全部數據

    zrange key start stop [witchscores]
    zrevrange key star stop [witchscores]
  • 刪除數據

    zrem key member [member ...]
  • 按條件查詢數據

    zrangebyscore key min max [withscores] [limit]
    zrevrangebyscore key max min [withscores]
  • 條件刪除數據

    zremrangebyrank key start stop   //start stop 表示索引的開始結束位置
    zremrangebyscore key min max     //min max表示排序的最小到最大位置
  • 獲取集合數據數量

    zcard key
    zcount key min max
  • 集合交、並操作

    zinterstore destination numkeys key [key ...]
    zunionstore destination key [key ...]

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

-Advertisement-
Play Games
更多相關文章
  • 預讀:用估計信息,去硬碟讀取數據到緩存。預讀100次,也就是估計將要從硬碟中讀取了100頁數據到緩存。 物理讀:查詢計劃生成好以後,如果緩存缺少所需要的數據,讓緩存再次去讀硬碟。物理讀10頁,從硬碟中讀取10頁數據到緩存。 邏輯讀:從緩存中取出所有數據。邏輯讀100次,也就是從緩存里取到100頁數據 ...
  • bitmap就是在一個二進位的數據中,每一個位代表一定的含義,這樣最終只需要存一個整型數據,就可以解釋出多個含義.業務中有一個欄位專門用來存儲用戶對某些功能的開啟和關閉,如果是傳統的思維,肯定是建一個欄位來存0代表關閉,1代表開啟,那麼如果功能很多或者需要加功能開關,就需要不停的創建欄位.使用bit ...
  • 背 景: 在MySQL中如果是有限的層次,比如我們事先如果可以確定這個樹的最大深度, 那麼所有節點為根的樹的深度均不會超過樹的最大深度,則我們可以直接通過left join來實現。 但很多時候我們是無法控制或者是知道樹的深度的。這時就需要在MySQL中用存儲過程(函數)來實現或者在程式中使用遞歸來實 ...
  • select A.* from tb_mend_enrol A, (select A.Typeid, A.address from tb_mend_enrol A group by A.Typeid, A.address having count(A.Typeid) >= 2 and count(A ...
  • [20191126]探究等待事件的本源2.txt--//做一個測試,驗證如果寫入控制文件慢也會影響提交性能.1.環境:SCOTT@book> @ ver1PORT_STRING VERSION BANNER x86_64/Linux 2.4.xx 11.2.0.4.0 Oracle Database ...
  • -- 1.提取此類數據中的1的索引位置,從1開始 例: 0001100001100 --> 4,5,10,11 create or replace function hazq_instr_contains( v_str in varchar2)return varchar2is v_count nu ...
  • 一、問題描述: 需要將工作界面上的一些已經離職的用戶狀態改為失效,並備註為離職 二、需要準備/拿到手的工具/條件/數據: 1.已離職人員名單(excel格式) 2.任意mongodb工具(筆者使用的是NoSQLBooster for Mongodb) 3.連接好的mongodb資料庫(有些網路/策略 ...
  • 在Web應用發展的初期,那時關係型資料庫受到了較為廣泛的關註和應用,原因是因為那時候Web站點基本上訪問和併發不高、交互也較少。而在後來,隨著訪問量的提升,使用關係型資料庫的Web站點多多少少都開始在性能上出現了一些瓶頸,為了剋服這一問題,Redis應運而生,讓我們通過本文一起來瞭解下Redis 是... ...
一周排行
    -Advertisement-
    Play Games
  • 1. 說明 /* Performs operations on System.String instances that contain file or directory path information. These operations are performed in a cross-pla ...
  • 視頻地址:【WebApi+Vue3從0到1搭建《許可權管理系統》系列視頻:搭建JWT系統鑒權-嗶哩嗶哩】 https://b23.tv/R6cOcDO qq群:801913255 一、在appsettings.json中設置鑒權屬性 /*jwt鑒權*/ "JwtSetting": { "Issuer" ...
  • 引言 集成測試可在包含應用支持基礎結構(如資料庫、文件系統和網路)的級別上確保應用組件功能正常。 ASP.NET Core 通過將單元測試框架與測試 Web 主機和記憶體中測試伺服器結合使用來支持集成測試。 簡介 集成測試與單元測試相比,能夠在更廣泛的級別上評估應用的組件,確認多個組件一起工作以生成預 ...
  • 在.NET Emit編程中,我們探討了運算操作指令的重要性和應用。這些指令包括各種數學運算、位操作和比較操作,能夠在動態生成的代碼中實現對數據的處理和操作。通過這些指令,開發人員可以靈活地進行算術運算、邏輯運算和比較操作,從而實現各種複雜的演算法和邏輯......本篇之後,將進入第七部分:實戰項目 ...
  • 前言 多表頭表格是一個常見的業務需求,然而WPF中卻沒有預設實現這個功能,得益於WPF強大的控制項模板設計,我們可以通過修改控制項模板的方式自己實現它。 一、需求分析 下圖為一個典型的統計表格,統計1-12月的數據。 此時我們有一個需求,需要將月份按季度劃分,以便能夠直觀地看到季度統計數據,以下為該需求 ...
  • 如何將 ASP.NET Core MVC 項目的視圖分離到另一個項目 在當下這個年代 SPA 已是主流,人們早已忘記了 MVC 以及 Razor 的故事。但是在某些場景下 SSR 還是有意想不到效果。比如某些靜態頁面,比如追求首屏載入速度的時候。最近在項目中回歸傳統效果還是不錯。 有的時候我們希望將 ...
  • System.AggregateException: 發生一個或多個錯誤。 > Microsoft.WebTools.Shared.Exceptions.WebToolsException: 生成失敗。檢查輸出視窗瞭解更多詳細信息。 內部異常堆棧跟蹤的結尾 > (內部異常 #0) Microsoft ...
  • 引言 在上一章節我們實戰了在Asp.Net Core中的項目實戰,這一章節講解一下如何測試Asp.Net Core的中間件。 TestServer 還記得我們在集成測試中提供的TestServer嗎? TestServer 是由 Microsoft.AspNetCore.TestHost 包提供的。 ...
  • 在發現結果為真的WHEN子句時,CASE表達式的真假值判斷會終止,剩餘的WHEN子句會被忽略: CASE WHEN col_1 IN ('a', 'b') THEN '第一' WHEN col_1 IN ('a') THEN '第二' ELSE '其他' END 註意: 統一各分支返回的數據類型. ...
  • 在C#編程世界中,語法的精妙之處往往體現在那些看似微小卻極具影響力的符號與結構之中。其中,“_ =” 這一組合突然出現還真不知道什麼意思。本文將深入剖析“_ =” 的含義、工作原理及其在實際編程中的廣泛應用,揭示其作為C#語法奇兵的重要角色。 一、下劃線 _:神秘的棄元符號 下劃線 _ 在C#中並非 ...