### zet 有序集合,元素为string类型,元素具有唯一性,不重复。
### 每个元素都会关联一个double类型的score,表示权重,通过权重将元素从小到大排序。没有修改操作
### 虽然每个元素必不相同,但是score可以相同
zadd key score1 member1 score2 member2 ... # 添加
zadd fruits 1.0 apple 2.4 banana 4 watermelon 5 orange
# 返回指定范围内的元素,索引从左侧开始,第一个元素为0,
# 索引可以是负数,表示从尾部开始计数,如-1表示最后一个元素;
# 当给定withscores选项时,元素和分值一并返回
zrange key start stop [withscores]
zrange fruits 0 -1
zrange fruits 0 -1 withscores
zrevrange key start stop [withscores] # 按照分值从大到小降序排列,其他同上
zrevrange fruits 0 -1 withscores
zrangebyscore key min max [withsocres] [limit offset count] # 返回score值在min和max之间的成员
zrangebyscore fruits 5 9
zrevrangebyscore key max min [withsocres] [limit offset count] # 按照分值降序排列,返回score值在max和min之间的成员
zrevrangebyscore fruits 5 4 withscores
zscore key member # 返回成员member的score值
zscore fruits apple
zrem key member1 member2 ... # 删除指定元素
zrem fruits banana watermelon
zremrangebyscore key min max # 删除权重在指定范围的元素
zremrangebyscore fruits 1 3
zremrangebyrank key start stop # 元素按照升序排列下,删除指定排名范围内的元素,排名从0开始
zremrangebyrank fruits 1 2
zincrby key increment member # 为有序集合指定元素的分值加上增量increment,如果没有这个集合、元素,则直接创建
zincrby fruits 1 banana
zcard key # 返回有序集合包含的元素数量
zcard fruits
zrank key member # 返回指定元素在有序集合中的排名,其中排名按照元素的分值从小到大排序
zrank fruits apple --> 1
zrevrank key member # 返回成员在有序集合中的逆序排名,排名到0结束
zrevrank fruits apple --> 3
zcount key min max # 返回有序集合在升序排列下分值在min和max之间的元素数量
zcount fruits 1 4
zunionstore destkey numkeys key [key...] # 计算并集,结果存储到destkey,numkeys指定进行计算的集合个数
zadd fruits-8-13 300 apple 200 banana 150 cherry
zadd fruits-8-14 250 apple 300 banana 100 cherry
zunionstore fruits-8-13&14 2 fruits-8-13 fruits-8-14 # 得到8月13、14两天所有水果的总数
zinterstore destkey numkeys key [key...] # 计算交集,结果存储到destkey,numkeys指定进行计算的集合个数
### HyperLogLog 使用常量空间估算大量元素的基数
### 即使输入元素的数量或体积非常非常大,计算基数所需的空间总是固定的,并且是很小的
### 每个HyperLogLog键花费12kb内存,可以计算接近2^64个基数
### HyperLogLog只会根据输入元素来计算基数,而不会存储输入元素,所有它不能返回输入的各个元素
pfadd key member [member...] # 将任意数量的元素添加到指定的HyperLogLog
pfadd unique::ip::counter 192.168.0.1
pfadd unique::ip::counter 192.168.10.1
pfcount key [key...] # 当之给定一个HyperLogLog时,返回给定HyperLogLog的基数估算值; 当给定多个HyperLogLog时,得出一个合并的HyperLogLog,并返回
pfcount unique::ip::counter
pfmerge destkey sourcekey [sourcekey...] # 将多个HyperLogLog合并成一个HyperLogLog,
# 合并后的HyperLogLog的基数估算是对所有HyperLogLog进行并集计算得出的
pfadd str1 apple banana cherry
pfadd str2 cherry durian mongo
pfmerge str1&str2 str1 str2
pfcount str1&str2