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 |