欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時(shí)間:2016年09月28日 11:40:11   作者:Joan  
這篇文章給大家整理了在操作Redis集合類型中的常用命令,文章總結(jié)的很全面,對(duì)大家學(xué)習(xí)Redis具有一定的參考借鑒價(jià)值,下面來(lái)一起看看吧。

集合類型介紹

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

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

     ①集合類型和列表類型還是都能存儲(chǔ)2^32-1個(gè)字符串

     ②集合類型是無(wú)序的,列表類型是有序的

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

下面我們一起來(lái)看一下語(yǔ)法。

1、增加刪除元素命令

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

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

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

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

smembers key

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

sismember key member

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

4、集合間運(yùn)算

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

這三個(gè)命令才能使Redis大顯身手!

我們先準(zhǔn)備點(diǎn)測(cè)試數(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)下面我們來(lái)介紹sdiff命令,這個(gè)命令實(shí)際上是差集運(yùn)算。

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

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)接下來(lái)我們介紹sinter命令,這個(gè)命令用來(lái)對(duì)多個(gè)集合執(zhí)行交集運(yùn)算。集合A與集合B的交集表示為A∩B,即所有屬于A且屬于B的元素構(gòu)成的集合。這個(gè)命令也同時(shí)支持傳入多個(gè)鍵,也是一樣,一步一步的做交集運(yùn)算。

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

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

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、獲得集合中元素的個(gè)數(shù)

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

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

6、進(jìn)行集合運(yùn)算并將結(jié)果存儲(chǔ)

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

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

例:

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、隨機(jī)獲得集合中的元素

srandmember key [count]

 

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

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

     (2)負(fù)值時(shí),獲得|count|個(gè)元素,但有可能相同。

其實(shí)這個(gè)隨機(jī)并不是非常隨機(jī),因?yàn)閷?shí)際上redis的集合用的是散列的存儲(chǔ)結(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、從集合中彈出一個(gè)元素

spop key

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

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

下面我們來(lái)舉例一個(gè)集合的具體應(yīng)用。

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

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

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

而在我們想要獲取比如同時(shí)屬于java和redis標(biāo)簽的文章時(shí),我們只需要對(duì)tag:java:poststag:redis:posts做交集運(yùn)算就OK了,是不是很方便呢?

總結(jié)

以上就是這篇文章的全部?jī)?nèi)容了,希望能對(duì)大家的學(xué)習(xí)或者工作帶來(lái)一定的幫助,如果有疑問(wèn)大家可以留言交流。

相關(guān)文章

  • 為Java項(xiàng)目添加Redis緩存的方法

    為Java項(xiàng)目添加Redis緩存的方法

    Redis一般有Linux和Windows兩種安裝方式,本文就這兩種方式給大家詳細(xì)介紹,對(duì)java項(xiàng)目添加redis緩存相關(guān)知識(shí),感興趣的朋友一起看看吧
    2021-05-05
  • Redis的BitMap使用操作命令

    Redis的BitMap使用操作命令

    Redis 為我們提供了位圖這一數(shù)據(jù)結(jié)構(gòu),每個(gè)用戶每天的登錄記錄只占據(jù)一位,365天就是365位,僅僅需要46字節(jié)就可存儲(chǔ),極大地節(jié)約了存儲(chǔ)空間,這篇文章主要介紹了Redis的BitMap使用操作命令,需要的朋友可以參考下
    2023-10-10
  • Redis三種集群搭建配置(主從集群、哨兵集群、分片集群)

    Redis三種集群搭建配置(主從集群、哨兵集群、分片集群)

    本文主要介紹了Redis三種集群搭建配置,包括主從集群、哨兵集群、分片集群,具有一定的參考價(jià)值,感興趣的可以了解一下
    2024-03-03
  • 如何利用Redis鎖解決高并發(fā)問(wèn)題詳解

    如何利用Redis鎖解決高并發(fā)問(wèn)題詳解

    redis鎖處理高并發(fā)問(wèn)題十分常見(jiàn),下面這篇文章主要給大家介紹了關(guān)于如何使用Redis鎖解決高并發(fā)問(wèn)題的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),需要的朋友可以參考借鑒,下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2018-09-09
  • Redis字典實(shí)現(xiàn)、Hash鍵沖突及漸進(jìn)式rehash詳解

    Redis字典實(shí)現(xiàn)、Hash鍵沖突及漸進(jìn)式rehash詳解

    這篇文章主要介紹了Redis字典實(shí)現(xiàn)、Hash鍵沖突以及漸進(jìn)式rehash的相關(guān)知識(shí),本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-09-09
  • SpringBoot整合Redis實(shí)現(xiàn)序列化存儲(chǔ)Java對(duì)象的操作方法

    SpringBoot整合Redis實(shí)現(xiàn)序列化存儲(chǔ)Java對(duì)象的操作方法

    這篇文章主要介紹了SpringBoot整合Redis實(shí)現(xiàn)序列化存儲(chǔ)Java對(duì)象,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-03-03
  • Python的Flask框架使用Redis做數(shù)據(jù)緩存的配置方法

    Python的Flask框架使用Redis做數(shù)據(jù)緩存的配置方法

    Redis數(shù)據(jù)庫(kù)依賴于主存,在關(guān)系型數(shù)據(jù)庫(kù)以外再配套R(shí)edis管理緩存數(shù)據(jù)將對(duì)性能會(huì)有很大的提升,這里我們就來(lái)看一下Python的Flask框架使用Redis做數(shù)據(jù)緩存的配置方法
    2016-06-06
  • Redis 實(shí)現(xiàn)隊(duì)列原理的實(shí)例詳解

    Redis 實(shí)現(xiàn)隊(duì)列原理的實(shí)例詳解

    這篇文章主要介紹了Redis 實(shí)現(xiàn)隊(duì)列原理的實(shí)例詳解的相關(guān)資料,希望通過(guò)本文能幫助到大家,需要的朋友可以參考下
    2017-09-09
  • Redis實(shí)現(xiàn)分布式Session管理的機(jī)制詳解

    Redis實(shí)現(xiàn)分布式Session管理的機(jī)制詳解

    這篇文章主要介紹了Redis實(shí)現(xiàn)分布式Session管理的機(jī)制詳解,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-01-01
  • Redis源碼解析:集群手動(dòng)故障轉(zhuǎn)移、從節(jié)點(diǎn)遷移詳解

    Redis源碼解析:集群手動(dòng)故障轉(zhuǎn)移、從節(jié)點(diǎn)遷移詳解

    這篇文章主要介紹了Redis源碼解析:集群手動(dòng)故障轉(zhuǎn)移、從節(jié)點(diǎn)遷移的相關(guān)內(nèi)容,涉及通過(guò)集群定時(shí)器函數(shù)clusterCron實(shí)現(xiàn)從節(jié)點(diǎn)遷移等知識(shí),具有一定參考價(jià)值,需要的朋友可以了解。
    2017-10-10

最新評(píng)論