Redis 命令 (三)

Redis 集合(Set) 命令

Redis Set是 string 类型的无序集合

Redis set 集合成员是唯一的,这就意味着集合中不能出现重复的数据

Redis set 是通过哈希表实现的,所以添加,删除,查找的复杂度都是 O(1)

Redis set 最大的成员数量为 232 – 1(4294967295)

范例

127.0.0.1:6379> SADD language PHP
(integer) 1
127.0.0.1:6379> SADD language Python
(integer) 1
127.0.0.1:6379> SADD language Perl
(integer) 1
127.0.0.1:6379> SADD language Python
(integer) 0
127.0.0.1:6379> SMEMBERS language

1) "Perl"
2) "Python"
3) "PHP"

上面的范例,我们通过 SADD 命令向名为 language 的集合插入的三个元素

Redis 集合命令
下表列出了 Redis 集合相关命令

命令描述
SADD向集合添加一个或多个成员
SCARD获取集合的成员数
SDIFF返回给定所有集合的差集
SDIFFSTORE返回给定所有集合的差集并存储在 destination 中
SINTER返回给定所有集合的交集
SINTERSTORE返回给定所有集合的交集并存储在 destination 中
SISMEMBER判断 member 元素是否是集合 key 的成员
SMEMBERS返回集合中的所有成员
SMOVE将 member 元素从 source 集合移动到 destination 集合
SPOP移除并返回集合中的一个随机元素
SRANDMEMBER返回集合中一个或多个随机数
SREM移除集合中一个或多个成员
SUNION返回所有给定集合的并集
SUNIONSTORE所有给定集合的并集存储在 destination 集合中
SSCAN迭代集合中的元素

Redis 有序集合(sorted set) 命令

Redis sorted set 和 set 一样也是 string 类型元素的集合,且不允许重复的成员

Redis sorted set 的每个元素都会关联一个 double 类型的分数(score)

Redis sorted set 通过分数(score) 来为集合中的成员进行从小到大的排序

Redis sorted set(有序集合) 的成员是唯一的,但分数 (score) 却可以重复

Redis sorted set 是通过哈希表实现的,所以添加,删除,查找的复杂度都是O(1)

Redis sorted set 中最大的成员数为 232 – 1

范例

127.0.0.1:6379> ZADD language 1 PHP
(integer) 1
127.0.0.1:6379> ZADD language 2 Python
(integer) 1
127.0.0.1:6379> ZADD language 3 Ruby
(integer) 1
127.0.0.1:6379> ZADD language 3 Perl
(integer) 0
127.0.0.1:6379> ZADD language 4 Perl
(integer) 0
127.0.0.1:6379> ZRANGE language 0 10 WITHSCORES

1) "PHP"
2) "1"
3) "Python"
4) "2"
5) "Ruby"
6) "3"
7) "Perl"
8) "4"

上面的范例,我们通过 ZADD 命令向 Redis 的有序集合中添加了三个值并关联上分数

Redis 有序集合命令
下表列出了 Redis 有序集合的基本命令

命令描述
ZADD向有序集合添加一个或多个成员,或者更新已存在成员的分数
ZCARD获取有序集合的成员数
ZCOUNT计算在有序集合中指定区间分数的成员数
ZINCRBY有序集合中对指定成员的分数加上增量 increment
ZINTERSTORE计算给定的一个或多个有序集的交集并将结果集存储在新的有序集合 key 中
ZLEXCOUNT在有序集合中计算指定字典区间内成员数量
ZRANGE通过索引区间返回有序集合成指定区间内的成员
ZRANGEBYLEX通过字典区间返回有序集合的成员
ZRANGEBYSCORE通过分数返回有序集合指定区间内的成员
ZRANK返回有序集合中指定成员的索引
ZREM移除有序集合中的一个或多个成员
ZREMRANGEBYLEX移除有序集合中给定的字典区间的所有成员
ZREMRANGEBYRANK移除有序集合中给定的排名区间的所有成员
ZREMRANGEBYSCORE移除有序集合中给定的分数区间的所有成员
ZREVRANGE返回有序集中指定区间内的成员,通过索引,分数从高到底
ZREVRANGEBYSCORE返回有序集中指定分数区间内的成员,分数从高到低排序
ZREVRANK返回有序集合中指定成员的排名,有序集成员按分数值递减(从大到小)排序
ZSCORE返回有序集中,成员的分数值
ZUNIONSTORE计算一个或多个有序集的并集,并存储在新的 key 中
ZSCAN迭代有序集合中的元素(包括元素成员和元素分值)

Redis HyperLogLog 命令

Redis 在 2.8.9 版本添加了 HyperLogLog 结构

Redis HyperLogLog 是用来做基数统计的算法

HyperLogLog 的优点是,在输入元素的数量或者体积非常非常大时,计算基数所需的空间总是固定 的、并且是很小的

每个 HyperLogLog 键只需要花费 12 KB 内存,就可以计算接近 2^64 个不同元素的基 数。这和计算基数时,元素越多耗费内存就越多的集合形成鲜明对比。

但是,因为 HyperLogLog 只会根据输入元素来计算基数,而不会储存输入元素本身,所以 HyperLogLog 不能像集合那样,返回输入的各个元素

什么是基数?
假如我们有一个数据集 {1, 3, 5, 7, 5, 7, 8}
那么这个数据集的基数集为 {1, 3, 5 ,7, 8}, 基数 (不重复元素个数) 为5

基数估计 就是在误差可接受的范围内,快速计算基数

范例
下面的范例演示了 HyperLogLog 的工作过程

127.0.0.1:6379> PFADD language "PHP"
1) (integer) 1
127.0.0.1:6379> PFADD language "Python"
1) (integer) 1
127.0.0.1:6379> PFADD language "Perl"
1) (integer) 1
127.0.0.1:6379> PFCOUNT language
(integer) 3

Redis HyperLogLog 命令
下表列出了 Redis HyperLogLog 命令

命令描述
PFADD添加指定元素到 HyperLogLog 中
PFCOUNT返回给定 HyperLogLog 的基数估算值
PFMERGE将多个 HyperLogLog 合并为一个 HyperLogLog
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

jysf98746

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值