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 zinterstore destkey numkeys key [key...] # 计算交集,结果存储到destkey,numkeys指定进行计算的集合个数 zunionstore fruits-8-13&14 2 fruits-8-13 fruits-8-14 # 得到8月13、14两天所有水果的总数
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
本文出自 “戴柏阳的博客” 博客,请务必保留此出处http://daibaiyang119.blog.51cto.com/3145591/1962376
Redis常用命令(三)有序集合键、HyperLogLog键
原文地址:http://daibaiyang119.blog.51cto.com/3145591/1962376