redis 的集合是無序的,集合成員是惟一的,不能重複。用戶能夠快速地對集合執行添加元素操做、移除元素操做以及檢查一個元素是否存在於集合中。這裏介紹一些經常使用的集合處理命令,並在 Yii 中的使用。redis
SADDapp
SADD:SADD key-name item [item …]
將一個或多個元素添加到集合裏面,並返回被添加元素當中本來並不存在於集合裏面的元素數量spa
SREMcode
SREM:SREM key-name item [item …]
從集合裏面移除一個或多個元素,並返回被移除元素的數量blog
SISMEMBERrem
SISMEMBER:SISMEMBER key-name item
檢查元素 item 是否存在於集合 key-name 裏it
SCARDclass
SCARD:SCARD key-name
返回集合包含的元素的數量test
SMEMBERSember
SMEMBERS:SMEMBERS key-name
返回集合包含的全部元素
SRANDMEMBER
SRANDMEMBER:SRANDMEMBER key-name [count]
從集合裏面隨機地返回一個或多個元素。當 count 爲正數時,命令返回地隨機元素不會重複;當 count 爲負數時,命令返回地隨機元素可能會出現重複
SPOP
SPOP:SPOP key-name
隨機地移除集合中的一個元素,並返回被移除的元素
SMOVE
SMOVE:SMOVE source-key dest-key item
若是 source-key 包含元素 item,那麼從集合 source-key 裏面移除元素 item,並將元素 item 添加到集合 dest-key 中;若是 item 被成功移除,那麼命令返回 1,不然返回 0
SDIFF
SDIFF:SDIFF key-name [key-name …]
返回那些存在於第一個集合、但不存在於其餘集合中的元素(計算差集)
SDIFFSTORE
SDIFFSTORE:SDIFFSTORE dest-key key-name [key-name …]
將那些存在於第一個集合但並不存在於其餘集合中的元素(差集)存儲到 dest-key 鍵裏面
SINTER
SINTER:SINTER key-name [key-name …]
返回那些同時存在於全部集合中的元素(計算交集)
SINTERSTORE
SINTERSTORE:SINTERSTORE dest-key key-name [key-name …]
將那些同時存在於全部集合的元素(交集)存儲到 dest-key 鍵裏面
SUNION
SUNION:SUNION key-name [key-name …]
返回那些至少存在於一個集合中的元素(計算並集)
SUNIONSTORE
SUNIONSTORE:SUNIONSTORE dest-key key-name [key-name …]
將那些至少存在於一個集合中的元素(並集)存儲到 dest-key 鍵裏面
在 Yii 中使用實例:
// 添加元素a,b,c Yii::$app->redis->sadd('testSetKey', 'a', 'b', 'c'); // 3 // 移除元素c Yii::$app->redis->srem('testSetKey', 'c'); // 1 // 檢查元素c是否存在集合中 Yii::$app->redis->sismember('testSetKey', 'c'); // 0 // 返回集合包含的元素的數量 Yii::$app->redis->scard('testSetKey'); // 2 // 返回集合包含的全部元素 Yii::$app->redis->smembers('testSetKey'); // ["a","b"] // 將元素a從testSetKey集合移到testSetKey2集合 Yii::$app->redis->smove('testSetKey', 'testSetKey2', 'a'); // 1 Yii::$app->redis->smembers('testSetKey'); // ["b"] Yii::$app->redis->smembers('testSetKey2'); // ["a"]