set 数据类型的应用场景
1. 簡介
set 數(shù)據(jù)類型是一個集合(沒有排序,不重復(fù)),可以對 set 類型的數(shù)據(jù)進行添加、刪除、判斷是否存在等操作(時間復(fù)雜度是 O(1) ) set 集合不允許數(shù)據(jù)重復(fù),如果添加的數(shù)據(jù)在 set 中已經(jīng)存在,將只保留一份。 set 類型提供了多個 set 之間的聚合運算,如求交、并、差集,這些操作在 redis 內(nèi)部完成,效率很高。
2. 數(shù)據(jù)模型
sadd key value [value...] //添加元素 srem key value [value...] //刪除元素 scard key //計算元素的個數(shù) sismember key value //判斷元素是否在集合中 srandmember key [count] //隨機從集合中返回指定個數(shù)的元素,不寫默認為1 spop key //從集合隨機取出元素 smembers key //獲取集合內(nèi)的所有元素sinter key1 key2 //求集合的交集 sunion key1 key2 //求集合的并集 sdiff key1 key2 //求集合的差集3. 應(yīng)用場景
set 類型的特點是——不重復(fù)且無序的一組數(shù)據(jù),并且具有豐富的計算功能,在一些特定的場景中可以高效的解決一般關(guān)系型數(shù)據(jù)庫不方便做的工作。
(1)“共同好友列表”
社交類應(yīng)用中,獲取兩個人或多個人的共同好友,兩個人或多個人共同關(guān)注的微博這樣類似的功能,用 MySQL 的話操作很復(fù)雜,可以把每個人的好友 id 存到集合中,獲取共同好友的操作就可以簡單到一個取交集的命令就搞定。
// 這里為了方便閱讀,把 id 替換成姓名 sadd user:wade james melo paul kobe sadd user:james wade melo paul kobe sadd user:paul wade james melo kobe sadd user:melo wade james paul kobe// 獲取 wade 和 james 的共同好友 sinter user:wade user:james /* 輸出:* 1) "kobe"* 2) "paul"* 3) "melo"*/// 獲取香蕉四兄弟的共同好友sinter user:wade user:james user:paul user:melo/* 輸出:* 1) "kobe"*//*類似的需求還有很多 , 必須把每個標(biāo)簽下的文章 id 存到集合中,可以很容易的求出幾個不同標(biāo)簽下的共同文章;把每個人的愛好存到集合中,可以很容易的求出幾個人的共同愛好。 */(2)唯一ip
跟蹤一些具有唯一性的一些數(shù)據(jù),比如訪問某一博客的唯一ip地址的信息,我們僅需要在每次訪問的時候,將ip存入redis中。利用服務(wù)器端聚合操作方便高效的特性,維護數(shù)據(jù)對象之間的關(guān)聯(lián)關(guān)系。
?
總結(jié)
以上是生活随笔為你收集整理的set 数据类型的应用场景的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: list 数据类型的应用场景
- 下一篇: sorted set 数据类型的应用场景