1. 概述
Redis Zunionstore 命令计算给定的一个或多个有序集的并集,其中给定 key 的数量必须以 numkeys 参数指定,并将该并集(结果集)储存到 destination 。
默认情况下,结果集中某个成员的分数值是所有给定集下该成员分数值之和 。
2. 语法
redis Zunionstore 命令基本语法如下:
redis > ZUNIONSTORE destination numkeys key [key ...] [WEIGHTS weight [weight ...]] [AGGREGATE SUM|MIN|MAX]
3. 实例
构建集合zset1 :
redis> ZADD zset1 1 "one"
(integer) 1
redis> ZADD zset1 2 "two"
构建集合zset2:
(integer) 1
redis> ZADD zset2 1 "one"
(integer) 1
redis> ZADD zset2 2 "two"
(integer) 1
redis> ZADD zset2 3 "three"
(integer) 1
不带权重计算并集:
127.0.0.1:6379> ZUNIONSTORE out 2 zset1 zset2
(integer) 3
127.0.0.1:6379> ZRANGE out 0 -1 WITHSCORES
1) "one"
2) "2" '1+1=2'
3) "three"
4) "3" '0+3=3'
5) "two"
6) "4" '2+2=4'
带权重计算并集:
redis> ZUNIONSTORE out 2 zset1 zset2 WEIGHTS 2 3
(integer) 3
redis> ZRANGE out 0 -1 WITHSCORES
1) "one"
2) "5" '1*2+1*3=5'
3) "three"
4) "9" '0*2+3*3=9'
5) "two"
6) "10" '2*2+2*3=10'
使用 WEIGHTS 选项时,可以为各个有序集合输入指定一个乘法系数(Multiplication factor )。这意味着在将每个有序集合输入中的每个元素的分值传递给聚合函数(Aggregation function)之前,会将该分值乘以对应的系数。
当未给定 WEIGHTS 选项时,乘法系数默认为 1
。