1. 程式人生 > 其它 >Redis學習筆記(二):Redis常用資料型別之set(集合)、zset(有序集合)的命令以及全域性命令詳解

Redis學習筆記(二):Redis常用資料型別之set(集合)、zset(有序集合)的命令以及全域性命令詳解

技術標籤:Redisredis

上一篇部落格說了str、hash和list三種資料型別,這篇部落格將會介紹五種資料型別的後兩種set和zset,分別是集合和有序集合。這兩個資料型別就我個人的開發經驗來說沒用過,一方面是不熟悉,一方面是前面的三種類型基本已經滿足了日常開發需求。在文章的最後還會補充說明一些全域性的命令,至此關於命令的內容就結束啦。寫的有點麻煩,但是寫完後有種發現新大陸的感覺,後期在使用redis的時候,選擇性知識體系將會更寬,不會僅限於一兩種資料型別啦。

redis資料型別之set

set集合和Java中的set集合有點像,內部元素是無序的,不可重複。單個鍵的value值裡面可以儲存2的32次方減1個元素。另外還可以直接做交、並、差集的運算。下面來一起了解一下set集合的常用命令。

常用命令

  • sadd key members:向集合中插入元素,一次可以插入多個元素,member值指定具體元素

    sadd user:1:tag it java js
    
  • smembers key:查詢集合中的所有元素

    smembers user:1:tag
    
  • srem key members:移除集合中的元素,可以一次移除多個,members值指定具體元素

    srem user:1:tag js
    
  • scard key:獲取當前集合元素個數

    scard user:1:tag
    
  • sdiff keys:取第一個集合和其他集合的差集

    sdiff user:2:tag user:1:tag
    

    這裡需要注意,sdiff user:2:tag user:1:tag

    sdiff user:1:tag user:2:tag結果是完全不同的,如現在user:1:tag中的元素是1、2、3、4,在user:2:tag中的元素是1、2、5、6,此時sdiff user:2:tag user:1:tag的結果是5、6,sdiff user:1:tag user:2:tag的結果是3、4。

  • sdiffstore destination keys:將取得的差集儲存的destination指定的集合中,如果destination指定的集合存在,直接覆蓋,如不存在,新增集合儲存

    sdiffstore difftags user:1:tag user:2:tag
    
  • sunion keys

    :取多個集合的並集

    sunion user:1:tag user:2:tag
    
  • sunionstore destination keys:取多個集合的並集,並將並集儲存到destination指定集合中,如果destination指定的集合存在,直接覆蓋,如不存在,新增集合儲存

    sunionstore uniontags user:1:tag user:2:tag
    
  • sinter keys:取多個集合之間的交集

    sinter user:1:tag user:2:tag
    
  • sinterstore destination keys:取多個集合之間的交集,並將交集儲存到destination指定集合中,如果destination指定的集合存在,直接覆蓋,如不存在,新增集合儲存

    sinterstore intertags user:1:tag user:2:tag
    

redis資料型別之zset

zset是有序的集合,內部元素不可重複,單個鍵下可以儲存2的32次方減1個元素。zset內部元素排序是通過當前元素的分數來的,預設採用正排序。一般用來做排行榜相關需求比較多。

常用命令

  • zadd key [nx|xx] [ch] [incr] scores members:新增zset型別資料,nx、xx為可選值,nx表示不可覆蓋,xx為可覆蓋,在zadd命令裡面ch、incr基本不用,可以使用zincrby替代。score表示分數,雙精度浮點數,以字串形式表示。

    zadd user 10 u1 15 u2 11 u3
    
  • zincrby key increment member:對zset集合中member對應的分數做累加操作,具體累加的數值有increment指定

    ### u1的分數累加10
    zincrby user 10 u1
    
  • zrange key start stop [withscores]:正排序,指定start和stop角標,這種角標的規則和list列表的角標規則相同,具體可以參考list列表角標的說明,withscores表示在返回值中包含分數

    ## 正序方式獲取前兩名的member和對應的分數
    zrange user 0 1 withscores
    
  • zrevrange key start stop [withscores]:反排序,指定start和stop角標,withscores表示在返回值中包含分數

    ## 反序方式獲取前兩名的member和對應的分數
    zrevrange user 0 1 withscores
    
  • zscore key member:查詢指定元素的分數值

    zscore user u1
    
  • zrank key member:正排序,獲取當前元素的排名

    zrank user u1
    
  • zrevrank key member:反排序,獲取當前元素的排序

    zrevrank user u1
    
  • zcount key min max:指定分數範圍內的元素個數,min和max表示分數的邊界

    zcount key 10 20
    

說明:正排序表示從小到大排序,分數越大越靠後,反排序表示從大到小,分數越高越靠前

redis全域性命令

redis有一些全域性命令是經常被使用的,比如刪除、設定有效時間等。下面列出經常使用的。

常用命令

  • del keys:根據key刪除,可以同時刪除多個

    del user:1 user:2
    
  • exists keys:判斷指定key是否存在

    exists user:1
    
  • flushdb:清空當前的資料庫,redis本身把資料庫分為16個部分,從0~15,可以通過select命令切換資料,flushdb是清空當前所在的資料庫部分

    flushdb
    
  • flushall:清空所有資料庫,將清除資料庫16個部分的所有資料

    flushall
    

    注意要分清楚flushallflushdb的區別,千萬不要用錯了,否則就尷尬啦。

  • dbsize:檢視當前資料庫存在的key總數

    dbsize
    
  • select index:切換到指定的資料庫,index可選值為0~15

    select 11
    
  • keys pattern:查詢當前資料庫的所有key

    keys *
    keys a*
    
  • expire key seconds:設定指定key的有效時間,單位秒

    ### 設定user:1有效時間為10秒,超過時間過期自動刪除
    expire user:1 10
    
  • ttl key:檢視當前key還有多長時間失效

    ttl user:1
    
  • type key:檢視當前key儲存資料的型別,型別有string、hash、set、zset、list

    type user:1
    

總結

到這裡基本的命令都寫完了,也都忘完了。在寫這些內容參考了很多東西,有個騰訊雲關於redis的說明,感覺很好,推薦給大家,可以參照一下。參考地址:https://cloud.tencent.com/developer/section/1374142