Redis基礎類型經常使用操做命令

Redis基礎類型經常使用操做命令

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

特徵:shell

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

應用場景

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

基礎數據類型之: String

單個string類型的存儲空間爲512MB數據庫

string基本操做

  • 添加或修改數據數組

    set key value
  • 獲取數據session

    get key
  • 刪除數據架構

    del key
  • 設置過時時間(默認單位爲秒)app

    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 ...]
相關文章
相關標籤/搜索