Redis基礎類型常用操作命令

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

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 ...]

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

更多相關文章
  • 預讀:用估計信息,去硬碟讀取數據到緩存。預讀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.環境:[email protected]> @ 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 是... ...
一周排行
  • C#實現(Delegate)的委托就不多說了,直接上代碼,看代碼中的註釋: namespace Delegate { delegate void DGSayiHi(string name);//聲明委托 delegate void DGDo(string name); class Program { ...
  • C#實現的從小到大的冒泡排序: public void BubbleSort(int[] array) { int length = array.Length; for (int i = 0; i < length - 1; i++) { for (int j = length - 1; j > i ...
  • string aa = DateTime.Now.ToShortDateString();//"2019/9/23" string bb = DateTime.Now.ToShortTimeString();//"上午 10:21" string ff = DateTime.Now.ToLongDa ...
  • 1. 什麼是,以及怎麼用畫中畫 Windows 10 Creators Update以後UWP提供了一個新的視圖模式CompactOverlay,中文翻譯成 緊湊的覆蓋層 ?反正大部分時間我們都會稱它為 畫中畫模式 。 上圖中右上角即為進入畫中畫模式的微軟“電影和電視”應用。 可以調用 "Appli ...
  • C#實現的對兩個Table進行Merge,兩表必須存在至少一個公共欄位作為連接項,否則連接就失去了意義。如下是對兩個table進行Merge的詳細代碼: private void button1_Click(object sender, EventArgs e)//Button點擊觸發事件 { #r ...
  • 在很多時候,我們做一些非常規化的界面的時候,往往需要創建一些用戶控制項,在其中繪製好一些基礎的界面塊,作為後續重覆使用的一個單元,用戶控制項同時也可以封裝處理一些簡單的邏輯。在開發Winform各種類型項目,我都時不時需要定製一些特殊的用戶控制項,以方便在界面模塊中反覆使用。我們一般是在自定義的用戶控制項里... ...
  • 第一部分:面向對象 封裝 繼承(里氏轉換) 多態第二部分:值類型、引用類型、字元串操作第三部分:集合文件操作第四部分:正則表達式第五部分:XML操作第六部分:委托、事件第七部分:反射。 //存儲著我們當前正在運行的進程//Process[] pro = Process.GetProcesses(); ...
  • 程式處理存放圖片的幾種方式 我的理解有4個: 1:放在項目本身得文件夾中,直接部署到伺服器上 2:存放在磁碟中,然後資料庫中存放路徑,讀取得時候傳路徑。這個適合小項目 3:將圖片轉換成二進位文件,但是不建議這樣做,因為會給資料庫造成壓力。 4:存放在雲存儲器上,也是在資料庫上存地址,不過是雲地址,使 ...
  • 什麼是AutoMapper?AutoMapper是一個簡單的小型庫,用於解決一個看似複雜的問題 - 擺脫將一個對象映射到另一個對象的代碼。這種類型的代碼是相當沉悶和無聊的寫,所以為什麼不發明一個工具來為我們做? 我們來看看在.netcore3.1中怎樣使用AutoMapper9.0。 Profile ...
  • Teigha中實體旋轉 代碼: using (var trans = database.TransactionManager.StartTransaction()) { Entity ent = trans.GetObject(entityId, OpenMode.ForWrite) asEntit ...
x