佳木斯湛栽影视文化发展公司

主頁 > 知識庫 > Redis集合類型的常用命令小結(jié)

Redis集合類型的常用命令小結(jié)

熱門標簽:呼叫中心市場需求 地方門戶網(wǎng)站 網(wǎng)站排名優(yōu)化 百度競價排名 鐵路電話系統(tǒng) AI電銷 Linux服務(wù)器 服務(wù)外包

集合類型介紹

集合類型也是體現(xiàn)redis一個比較高價值的一個類型了。因為Redis的集合類型,所以我們可以很容易的在Redis中執(zhí)行差集運算、交集運算、并集運算。

首先我們先介紹一下集合類型和列表類型的區(qū)別,其實學過面向?qū)ο蟮恼Z言的同學應該都能猜到這些類型有什么不同。

     ①集合類型和列表類型還是都能存儲2^32-1個字符串

     ②集合類型是無序的,列表類型是有序的

     ③集合類型是唯一的,列表類型的值是不唯一的

下面我們一起來看一下語法。

1、增加刪除元素命令

sadd key member [member ...]
srem key member [member ...]

sadd命令是用來向集合中增加元素的,當然根據(jù)前面的學習經(jīng)驗,如果集合不存在,肯定是會自動創(chuàng)建的。但是這里有點需要注意的是,如果元素已存在,那么他會忽略而不會覆蓋。返回值是成功加入元素的數(shù)量(忽略的元素不算)。

srem命令也是一樣,刪除元素,如果元素存在才會刪除成功,返回值是成功刪除的元素的個數(shù)。

2、獲得集合中的所有元素

smembers key

3、判斷元素是否在集合中

sismember key member

這個判斷操作的時間復雜度是O(1),無論集合中的元素有多少,這個命令始終都很很快的返回結(jié)果。存在返回1,不存在或沒有這個鍵的時候都返回0 。

4、集合間運算

sdiff key [key ...]
sinter key [key ...]
sunion key [key ...]

這三個命令才能使Redis大顯身手!

我們先準備點測試數(shù)據(jù)。

127.0.0.1:6379> sadd setA 1 2 3
(integer) 3
127.0.0.1:6379> sadd setB 2 3 4
(integer) 3
127.0.0.1:6379> sadd setC 3 4 5
(integer) 3
127.0.0.1:6379> smembers setA 
1) "1"
2) "2"
3) "3"
127.0.0.1:6379>

(1)下面我們來介紹sdiff命令,這個命令實際上是差集運算。

集合A與集合B的差值運算表示為A-B,代表所有屬于A且不屬于B的元素構(gòu)成的集合。這個命令同時支持傳入多個鍵,意思是A與B先做差集運算,然后結(jié)果再與C做差集運算。

127.0.0.1:6379> sdiff setA setB
1) "1"
127.0.0.1:6379> sdiff setB setC
1) "2"
127.0.0.1:6379> sdiff setA setB setC
1) "1"

(2)接下來我們介紹sinter命令,這個命令用來對多個集合執(zhí)行交集運算。集合A與集合B的交集表示為A∩B,即所有屬于A且屬于B的元素構(gòu)成的集合。這個命令也同時支持傳入多個鍵,也是一樣,一步一步的做交集運算。

127.0.0.1:6379> sinter setA setB
1) "2"
2) "3"
127.0.0.1:6379> sinter setA setB setC
1) "3"

(3)最后我們介紹并集運算命令sunion。集合A與集合B的并集意思是既屬于A也屬于B的集合。同樣支持多個鍵傳入。

127.0.0.1:6379> sunion setA setB
1) "1"
2) "2"
3) "3"
4) "4"
127.0.0.1:6379> sunion setA setB setC
1) "1"
2) "2"
3) "3"
4) "4"
5) "5"

5、獲得集合中元素的個數(shù)

scard key
127.0.0.1:6379> scard setA
(integer) 3
127.0.0.1:6379> scard setB
(integer) 3

這條命令用來獲取集合中元素的個數(shù)。同樣集合不存在返回0 。

6、進行集合運算并將結(jié)果存儲

sdiffstore destination key [key ...]
sinterstore destination key [key ...]
sunionstore destination key [key ...]

這里在所有的集合命令之后加了個store,很清楚就是存儲的意思了。destination就是目的地,也就是我們要存儲的鍵名。

例:

127.0.0.1:6379> sunionstore setAll setA setB setC
(integer) 5
127.0.0.1:6379> smembers setAll
1) "1"
2) "2"
3) "3"
4) "4"
5) "5"

7、隨機獲得集合中的元素

srandmember key [count]

 

這個命令用來隨機從集合中獲取一個元素,count參數(shù)用來一詞獲取多個元素,根據(jù)count的正負有不同的意義。

     (1)當count為正數(shù)時,獲取count個不重復的元素,如果count大于所有值的個數(shù),則返回全部元素。

     (2)負值時,獲得|count|個元素,但有可能相同。

其實這個隨機并不是非常隨機,因為實際上redis的集合用的是散列的存儲結(jié)構(gòu),有興趣的讀者可以自己深入研究一下。

127.0.0.1:6379> srandmember setA 1
1) "1"
127.0.0.1:6379> srandmember setA 2
1) "3"
2) "2"
127.0.0.1:6379> SRANDMEMBER setA 5
1) "1"
2) "2"
3) "3"
127.0.0.1:6379> SRANDMEMBER setA -2
1) "3"
2) "3"

8、從集合中彈出一個元素

spop key

之前我們也看過lpop與rpop,那是從列表中彈出,但是集合是無序的,所以spop是隨機彈出。 (彈出的元素被刪除,不在原來的集合中)

127.0.0.1:6379> spop setA 1
1) "2"
127.0.0.1:6379> smembers setA
1) "1"
2) "3"

下面我們來舉例一個集合的具體應用。

在我們文章存儲的時候有個標簽tag,這個我們在關(guān)系數(shù)據(jù)庫的時候都需要使用中間表關(guān)聯(lián)。但是在Redis中,我們可以很方便的處理。

對每篇文章,我們使用一個post:文章ID:tags的鍵,類型為集合,存儲一篇文章所屬的tags,這樣本身關(guān)系型數(shù)據(jù)庫我們需要關(guān)聯(lián)文章表、標簽表、中間關(guān)系表三個表的復雜操作,在Redis中就很好處理了。

有時候我們還需要獲取指定標簽的所有文章,我們還需要增加一類的鍵,即tag:標簽名稱:posts的集合類型鍵,存儲每個標簽的文章ID集合,這樣我們每次想要獲取所有屬于某個標簽的文章列表的時候也不用像關(guān)系數(shù)據(jù)庫那樣關(guān)聯(lián)那么多表,而是直接通過鍵就可以直接獲得了。

而在我們想要獲取比如同時屬于java和redis標簽的文章時,我們只需要對tag:java:poststag:redis:posts做交集運算就OK了,是不是很方便呢?

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望能對大家的學習或者工作帶來一定的幫助,如果有疑問大家可以留言交流。

您可能感興趣的文章:
  • Redis的5種數(shù)據(jù)類型與常用命令講解
  • Redis安裝及基本數(shù)據(jù)類型
  • Redis中3種特殊的數(shù)據(jù)類型(BitMap、Geo和HyperLogLog)
  • Jedis對redis的五大類型操作代碼詳解
  • redis字符串類型_動力節(jié)點Java學院整理
  • redis數(shù)據(jù)類型_動力節(jié)點Java學院整理
  • Redis有序集合類型的操作_動力節(jié)點Java學院整理
  • redis列表類型_動力節(jié)點Java學院整理
  • redis集合類型_動力節(jié)點Java學院整理
  • redis哈希類型_動力節(jié)點Java學院整理
  • Redis 數(shù)據(jù)類型的詳解
  • Redis中五種數(shù)據(jù)類型簡單操作
  • Redis列表類型的常用命令小結(jié)
  • Redis中散列類型的常用命令小結(jié)
  • Redis字符串類型的常用命令小結(jié)
  • Redis有序集合類型的常用命令小結(jié)
  • Redis02 使用Redis數(shù)據(jù)庫(String類型)全面解析
  • redis基本類型和使用方法詳解

標簽:崇左 仙桃 湖南 湘潭 衡水 銅川 黃山 蘭州

巨人網(wǎng)絡(luò)通訊聲明:本文標題《Redis集合類型的常用命令小結(jié)》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    兴安盟| 县级市| 阿克苏市| 台东县| 洛南县| 芜湖市| 四子王旗| 通辽市| 宜兰市| 玉山县| 封开县| 永平县| 武川县| 聂拉木县| 蕲春县| 珠海市| 竹溪县| 长沙市| 谢通门县| 嘉义县| 襄垣县| 云霄县| 射洪县| 当阳市| 临清市| 友谊县| 深州市| 巴彦淖尔市| 峡江县| 哈尔滨市| 凭祥市| 鄂托克前旗| 枞阳县| 彩票| 岳池县| 南阳市| 金平| 永宁县| 昆山市| 宝兴县| 汉中市|