文章目录
- set简介
- 添加命令
- 查询命令
- 移动/删除命令
- 集合运算命令
- 差集运算
- 交集运算
- 并集运算
- 应用场景
set简介
redis集合set类型和list列表类型类似,都可以用来存储多个字符串元素的集合。但是和list不同的是set集合当中不允许重复的元素。而且set集合当中元素是没有顺序的,不存在元素下标。
redis的set类型是使用哈希表构造的,它支持集合内的增删改查,并且支持多个集合间的交集、并集、差集操作。可以利用这些集合操作,解决程序开发过程当中很多数据集合间的问题。
集合中最大的成员数为 2^32 - 1 (4294967295, 每个集合可存储40多亿个成员)。
添加命令
sadd key member [member ...]
将一个或多个值加入到集合中,返回值数字,添加成功的个数,如果元素已经存在,则不会添加
127.0.0.1:6379> sadd name zhangsan lisi
(integer) 2
查询命令
scard key
获取集合中的元素个数smembers key
返回集合中的所有成员sismember key member
判断 member 元素是否是集合 key 的成员,1表示存在 0表示不存在或者该key本身就不存在-
srandmember key [count]
随机返回集合中一个或多个元素,默认随机1个
127.0.0.1:6379> scard name
(integer) 2
127.0.0.1:6379> smembers name
1) "zhangsan"
2) "lisi"
127.0.0.1:6379> sismember name zhangsan
(integer) 1
127.0.0.1:6379> sismember name wangwu
(integer) 0
127.0.0.1:6379> srandmember name
"zhangsan"
127.0.0.1:6379> srandmember name
"lisi"
127.0.0.1:6379> srandmember name 2
1) "zhangsan"
2) "lisi"
-
sscan key cursor [MATCH pattern] [COUNT count]
迭代集合中的元素cursor
:游标,HSCAN 命令每次被调用之后, 都会向用户返回一个新的游标, 用户在下次迭代时需要使用这个新游标作为 HSCAN 命令的游标参数, 以此来延续之前的迭代过程。当 SCAN 命令的游标参数被设置为 0 时, 服务器将开始一次新的迭代, 而当服务器向用户返回值为 0 的游标时, 表示迭代已结束
MATCH pattern
:匹配的模式,和 KEYS 命令一样, 增量式迭代命令也可以通过提供一个 glob 风格的模式参数, 让命令只返回和给定模式相匹配的元素, 这一点可以通过在执行增量式迭代命令时, 通过给定 MATCH 参数来实现
count
:指定从数据集里返回多少元素,默认值为 10 。虽然增量式迭代命令不保证每次迭代所返回的元素数量, 但我们可以使用 COUNT 选项, 对命令的行为进行一定程度上的调整。 基本上, COUNT 选项的作用就是让用户告知迭代命令, 在每次迭代中应该从数据集里返回多少元素java 127.0.0.1:6379> sscan name 0 match z* 1) "0" 2) 1) "zhangsan" 127.0.0.1:6379> sscan name 0 match z* count 1 1) "3" 2) 1) "zhangsan"
移动/删除命令
smove source destination member
将 member 元素从 source 集合移动到 destination 集合,成功返回1=spop key [count]
移除并返回集合中的一个随机元素,集合无元素时返回(empty list or set)srem key member [member ...]
移除集合中指定的一个或多个成员
127.0.0.1:6379> smove name name_bak lisi
(integer) 1
127.0.0.1:6379> smove name name_bak lisi
(integer) 0
127.0.0.1:6379> smembers name_bak
1) "lisi"
127.0.0.1:6379> spop name 1
1) "zhangsan"
127.0.0.1:6379> sadd name zhangsan lisi wangwu
(integer) 3
127.0.0.1:6379> srem name lisi wangwu
(integer) 2
127.0.0.1:6379> smembers name
1) "zhangsan"
集合运算命令
差集运算
sdiff key [key ...]
返回第一个集合与其他集合之间的差异。sdiffstore destination key [key ...]
返回给定所有集合的差集并存储在 destination 中
127.0.0.1:6379> sadd num1 1 2 3 5 6 8 9 12
(integer) 8
127.0.0.1:6379> sadd num2 2 3 4 6 9 10 11
(integer) 7
127.0.0.1:6379> sdiff num1 num2
1) "1"
2) "5"
3) "8"
4) "12"
127.0.0.1:6379> sdiffstore num3 num1 num2
(integer) 4
127.0.0.1:6379> smembers num3
1) "1"
2) "5"
3) "8"
4) "12"
交集运算
sinter key [key ...]
返回给定所有集合的交集sinterstore destination key [key ...]
返回给定所有集合的交集并存储在 destination 中
127.0.0.1:6379> sinter num1 num2
1) "2"
2) "3"
3) "6"
4) "9"
127.0.0.1:6379> sinterstore num4 num1 num2
(integer) 4
127.0.0.1:6379> smembers num4
1) "2"
2) "3"
3) "6"
4) "9"
并集运算
sunion key [key ...]
返回所有给定集合的并集sunionstore destination key [key ...]
所有给定集合的并集存储在 destination 集合中
127.0.0.1:6379> sunion num1 num2
1) "1"
2) "2"
3) "3"
4) "4"
5) "5"
6) "6"
7) "8"
8) "9"
9) "10"
10) "11"
11) "12"
127.0.0.1:6379> sunionstore num5 num1 num2
(integer) 11
127.0.0.1:6379> smembers num5
1) "1"
2) "2"
3) "3"
4) "4"
5) "5"
6) "6"
7) "8"
8) "9"
9) "10"
10) "11"
11) "12"
应用场景
- 好友、关注、粉丝、感兴趣的人集合:
1)sinter命令可以获得A和B两个用户的共同好友;
2)sismember命令可以判断A是否是B的好友;
3)scard命令可以获取好友数量;
4)关注时,smove命令可以将B从A的粉丝集合转移到A的好友集合 - 首页展示随机:美团首页有很多推荐商家,但是并不能全部展示,set类型适合存放所有需要展示的内容,而srandmember命令则可以从中随机获取几个。
- 存储某活动中中奖的用户ID ,因为有去重功能,可以保证同一个用户不会中奖两次。