集合类型介绍
集合类型也是体现redis一个比较高价值的一个类型了。因为Redis的集合类型,所以我们可以很容易的在Redis中执行差集运算、交集运算、并集运算。
首先我们先介绍一下集合类型和列表类型的区别,其实学过面向对象的语言的同学应该都能猜到这些类型有什么不同。
①集合类型和列表类型还是都能存储2^32-1个字符串
②集合类型是无序的,列表类型是有序的
③集合类型是唯一的,列表类型的值是不唯一的
下面我们一起来看一下语法。
1、增加删除元素命令
sadd key member [member ...] srem key member [member ...]
sadd
命令是用来向集合中增加元素的,当然根据前面的学习经验,如果集合不存在,肯定是会自动创建的。但是这里有点需要注意的是,如果元素已存在,那么他会忽略而不会覆盖。返回值是成功加入元素的数量(忽略的元素不算)。
srem
命令也是一样,删除元素,如果元素存在才会删除成功,返回值是成功删除的元素的个数。
2、获得集合中的所有元素
smembers key
3、判断元素是否在集合中
sismember key member
这个判断操作的时间复杂度是O(1),无论集合中的元素有多少,这个命令始终都很很快的返回结果。存在返回1,不存在或没有这个键的时候都返回0 。
4、集合间运算
sdiff key [key ...] sinter key [key ...] sunion key [key ...]
这三个命令才能使Redis大显身手!
我们先准备点测试数据。
127.0.0.1:6379> sadd setA 1 2 3 (integer) 3 127.0.0.1:6379> sadd setB 2 3 4 (integer) 3 127.0.0.1:6379> sadd setC 3 4 5 (integer) 3
127.0.0.1:6379> smembers setA 1) "1" 2) "2" 3) "3" 127.0.0.1:6379>
(1)下面我们来介绍sdiff
命令,这个命令实际上是差集运算。
集合A与集合B的差值运算表示为A-B,代表所有属于A且不属于B的元素构成的集合。这个命令同时支持传入多个键,意思是A与B先做差集运算,然后结果再与C做差集运算。
127.0.0.1:6379> sdiff setA setB 1) "1" 127.0.0.1:6379> sdiff setB setC 1) "2" 127.0.0.1:6379> sdiff setA setB setC 1) "1"
(2)接下来我们介绍sinter
命令,这个命令用来对多个集合执行交集运算。集合A与集合B的交集表示为A∩B,即所有属于A且属于B的元素构成的集合。这个命令也同时支持传入多个键,也是一样,一步一步的做交集运算。
127.0.0.1:6379> sinter setA setB 1) "2" 2) "3" 127.0.0.1:6379> sinter setA setB setC 1) "3"
(3)最后我们介绍并集运算命令sunion
。集合A与集合B的并集意思是既属于A也属于B的集合。同样支持多个键传入。
127.0.0.1:6379> sunion setA setB 1) "1" 2) "2" 3) "3" 4) "4" 127.0.0.1:6379> sunion setA setB setC 1) "1" 2) "2" 3) "3" 4) "4" 5) "5"
5、获得集合中元素的个数
scard key 127.0.0.1:6379> scard setA (integer) 3 127.0.0.1:6379> scard setB (integer) 3
这条命令用来获取集合中元素的个数。同样集合不存在返回0 。
6、进行集合运算并将结果存储
sdiffstore destination key [key ...] sinterstore destination key [key ...] sunionstore destination key [key ...]
这里在所有的集合命令之后加了个store
,很清楚就是存储的意思了。destination
就是目的地,也就是我们要存储的键名。
例:
127.0.0.1:6379> sunionstore setAll setA setB setC (integer) 5 127.0.0.1:6379> smembers setAll 1) "1" 2) "2" 3) "3" 4) "4" 5) "5"
7、随机获得集合中的元素
srandmember key [count]
这个命令用来随机从集合中获取一个元素,count参数用来一词获取多个元素,根据count的正负有不同的意义。
(1)当count为正数时,获取count个不重复的元素,如果count大于所有值的个数,则返回全部元素。
(2)负值时,获得|count|个元素,但有可能相同。
其实这个随机并不是非常随机,因为实际上redis的集合用的是散列的存储结构,有兴趣的读者可以自己深入研究一下。
127.0.0.1:6379> srandmember setA 1 1) "1" 127.0.0.1:6379> srandmember setA 2 1) "3" 2) "2" 127.0.0.1:6379> SRANDMEMBER setA 5 1) "1" 2) "2" 3) "3" 127.0.0.1:6379> SRANDMEMBER setA -2 1) "3" 2) "3"
8、从集合中弹出一个元素
spop key
之前我们也看过lpop与rpop,那是从列表中弹出,但是集合是无序的,所以spop是随机弹出。 (弹出的元素被删除,不在原来的集合中)
127.0.0.1:6379> spop setA 1 1) "2" 127.0.0.1:6379> smembers setA 1) "1" 2) "3"
下面我们来举例一个集合的具体应用。
在我们文章存储的时候有个标签tag,这个我们在关系数据库的时候都需要使用中间表关联。但是在Redis中,我们可以很方便的处理。
对每篇文章,我们使用一个post:文章ID:tags
的键,类型为集合,存储一篇文章所属的tags,这样本身关系型数据库我们需要关联文章表、标签表、中间关系表三个表的复杂操作,在Redis中就很好处理了。
有时候我们还需要获取指定标签的所有文章,我们还需要增加一类的键,即tag:标签名称:posts
的集合类型键,存储每个标签的文章ID集合,这样我们每次想要获取所有属于某个标签的文章列表的时候也不用像关系数据库那样关联那么多表,而是直接通过键就可以直接获得了。
而在我们想要获取比如同时属于java和redis标签的文章时,我们只需要对tag:java:posts
和tag:redis:posts
做交集运算就OK了,是不是很方便呢?
总结
以上就是这篇文章的全部内容了,希望能对大家的学习或者工作带来一定的帮助,如果有疑问大家可以留言交流。
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。
更新动态
- 凤飞飞《我们的主题曲》飞跃制作[正版原抓WAV+CUE]
- 刘嘉亮《亮情歌2》[WAV+CUE][1G]
- 红馆40·谭咏麟《歌者恋歌浓情30年演唱会》3CD[低速原抓WAV+CUE][1.8G]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[320K/MP3][193.25MB]
- 【轻音乐】曼托凡尼乐团《精选辑》2CD.1998[FLAC+CUE整轨]
- 邝美云《心中有爱》1989年香港DMIJP版1MTO东芝首版[WAV+CUE]
- 群星《情叹-发烧女声DSD》天籁女声发烧碟[WAV+CUE]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[FLAC/分轨][748.03MB]
- 理想混蛋《Origin Sessions》[320K/MP3][37.47MB]
- 公馆青少年《我其实一点都不酷》[320K/MP3][78.78MB]
- 群星《情叹-发烧男声DSD》最值得珍藏的完美男声[WAV+CUE]
- 群星《国韵飘香·贵妃醉酒HQCD黑胶王》2CD[WAV]
- 卫兰《DAUGHTER》【低速原抓WAV+CUE】
- 公馆青少年《我其实一点都不酷》[FLAC/分轨][398.22MB]
- ZWEI《迟暮的花 (Explicit)》[320K/MP3][57.16MB]