redis 的集合是无序的,集合成员是唯一的,不能重复。用户可以快速地对集合执行添加元素操作、移除元素操作以及检查一个元素是否存在于集合中。这里介绍一些常用的集合处理命令,并在 Yii 中的使用。
SADD
> SADD:SADD key-name item \[item …\]
> 将一个或多个元素添加到集合里面,并返回被添加元素当中原本并不存在于集合里面的元素数量
SREM
> SREM:SREM key-name item \[item …\]
> 从集合里面移除一个或多个元素,并返回被移除元素的数量
SISMEMBER
> SISMEMBER:SISMEMBER key-name item
> 检查元素 item 是否存在于集合 key-name 里
SCARD
> SCARD:SCARD key-name
> 返回集合包含的元素的数量
SMEMBERS
> 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"]
```