Redis學習筆記(二):Redis常用資料型別之set(集合)、zset(有序集合)的命令以及全域性命令詳解
上一篇部落格說了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
注意要分清楚
flushall
和flushdb
的區別,千萬不要用錯了,否則就尷尬啦。 -
dbsize
:檢視當前資料庫存在的key總數dbsize
-
select index
:切換到指定的資料庫,index可選值為0~15select 11
-
keys pattern
:查詢當前資料庫的所有keykeys * 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、listtype user:1
總結
到這裡基本的命令都寫完了,也都忘完了。在寫這些內容參考了很多東西,有個騰訊雲關於redis的說明,感覺很好,推薦給大家,可以參照一下。參考地址:https://cloud.tencent.com/developer/section/1374142