1 set 类型特征
- 新的存储需求:存储大量的数据,在查询方面提供更高的效率。
- 需要的存储结构:能够保存大量的数据,高效的内部存储机制,便于查询。
- set类型:与hash存储结构完全相同,仅存储键,不存储值(nil),并且值是不允许重复的。
- Set可包含的最大元素数量是4294967295。
2 set 类型数据的基本操作
2.1 添加数据
sadd key member1 [member2]
2.2 获取全部数据
smembers key
2.3 删除数据
srem key member1 [member2]
2.4 获取集合数据总量
scard key
2.5 判断集合中是否包含指定数据
sismember key member
2.6 随机获取集合中指定数量的数据
srandmember key [count]
2.7 随机获取集合中的某个数据并将该数据移出集合
spop key [count]
2.8 求两个集合的交、并、差集
sinter key1 [key2]
sunion key1 [key2]
sdiff key1 [key2]
2.9 求两个集合的交、并、差集并存储到指定集合中
sinterstore destination key1 [key2]
sunionstore destination key1 [key2]
sdiffstore destination key1 [key2]
2.10 将指定数据从原始集合中移动到目标集合中
smove source destination member
3 案例演示
(1)添加set元素
添加三个元素
127.0.0.1:6379> sadd set1 a b c
(integer) 3
(2)smembers查看指定key集合元素
127.0.0.1:6379> smembers set1
1) "c"
2) "b"
3) "a"
127.0.0.1:6379> sadd set1 a d e
(integer) 2
127.0.0.1:6379> smembers set1
1) "c"
2) "d"
3) "b"
4) "a"
5) "e"
继续添加元素 发现 重复元素不再添加
(3)srem删除元素
删除两个元素
127.0.0.1:6379> srem set1 a d
(integer) 2
127.0.0.1:6379> smembers set1
1) "b"
2) "c"
3) "e"
(4)sismember 判断某个元素是否存在 返回1 表示存在 返回0表示不存在
127.0.0.1:6379> sismember set1 a
(integer) 0
127.0.0.1:6379> sismember set1 b
(integer) 1
(5)sdiff计算差集
我们发现 集合的顺序不同 结果不一样 根据前者参考
127.0.0.1:6379> sadd set2 a b c
(integer) 3
127.0.0.1:6379> sadd set3 b c d e
(integer) 4
127.0.0.1:6379> sdiff set2 set3
1) "a"
127.0.0.1:6379> sdiff set3 set2
1) "d"
2) "e"
(6)sinter计算交集
127.0.0.1:6379> sinter set2 set3
1) "c"
2) "b"
(7)sunion计算并集
127.0.0.1:6379> sunion set2 set3
1) "e"
2) "a"
3) "b"
4) "c"
5) "d"
(8)scard计算元素总数
127.0.0.1:6379> smembers set1
1) "b"
2) "c"
3) "e"
127.0.0.1:6379> scard set1
(integer) 3
(9)srandmember 随机取一个元素
127.0.0.1:6379> srandmember set1
"c"
127.0.0.1:6379> srandmember set1
"e"
(10)sdiffstore 把差集结果存储到新集合中
127.0.0.1:6379> smembers set2
1) "c"
2) "b"
3) "a"
127.0.0.1:6379> smembers set3
1) "c"
2) "e"
3) "d"
4) "b"
127.0.0.1:6379> sdiffstore r1 set2 set3
(integer) 1
127.0.0.1:6379> smembers r1
1) "a"
(11)sinterstore 把交集结果存储到新集合中
127.0.0.1:6379> sinterstore r2 set2 set3
(integer) 2
127.0.0.1:6379> smembers r2
1) "c"
2) "b"
(12)sunionstore把并集结果存储到新集合中
127.0.0.1:6379> sunionstore r3 set2 set3
(integer) 5
127.0.0.1:6379> smembers r3
1) "e"
2) "a"
3) "b"
4) "c"
5) "d"
存储Set使用场景
跟踪一些唯一性数据
用于维护数据对象之间的关联关系