Redis 集合(Set)

Redis的Set是string类型的无序集合。集合成员是唯一的,这就意味着集合中不能出现重复的数据。

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

集合中最大的成员数为 232 - 1 (4294967295, 每个集合可存储40多亿个成员)。

实例

redis 127.0.0.1:6379> SADD runoobkey redis (integer) 1 redis 127.0.0.1:6379> SADD runoobkey mongodb (integer) 1 redis 127.0.0.1:6379> SADD runoobkey mysql (integer) 1 redis 127.0.0.1:6379> SADD runoobkey mysql (integer) 0 redis 127.0.0.1:6379> SMEMBERS runoobkey 1) "mysql" 2) "mongodb" 3) "redis"

在以上实例中我们通过 SADD 命令向名为 runoobkey 的集合插入的三个元素。


Redis 集合命令

下表列出了 Redis 集合基本命令:

 

序号

命令及描述

1

SADD key member1 [member2] 

向集合添加一个或多个成员

2

SCARD key 

获取集合的成员数

3

SDIFF key1 [key2] 

返回给定所有集合的差集

4

SDIFFSTORE destination key1 [key2] 

返回给定所有集合的差集并存储在 destination 中

5

SINTER key1 [key2] 

返回给定所有集合的交集

6

SINTERSTORE destination key1 [key2] 

返回给定所有集合的交集并存储在 destination 中

7

SISMEMBER key member 

判断 member 元素是否是集合 key 的成员

8

SMEMBERS key 

返回集合中的所有成员

9

SMOVE source destination member 

将 member 元素从 source 集合移动到 destination 集合

10

SPOP key 

移除并返回集合中的一个随机元素

11

SRANDMEMBER key [count] 

返回集合中一个或多个随机数

12

SREM key member1 [member2] 

移除集合中一个或多个成员

13

SUNION key1 [key2] 

返回所有给定集合的并集

14

SUNIONSTORE destination key1 [key2] 

所有给定集合的并集存储在 destination 集合中

15

SSCAN key cursor [MATCH pattern] [COUNT count] 

迭代集合中的元素

Redis 有序集合(sorted set)

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

不同的是每个元素都会关联一个double类型的分数。redis正是通过分数来为集合中的成员进行从小到大的排序。

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

集合是通过哈希表实现的,所以添加,删除,查找的复杂度都是O(1)。 集合中最大的成员数为 232 - 1 (4294967295, 每个集合可存储40多亿个成员)。

实例

redis 127.0.0.1:6379> ZADD runoobkey 1 redis (integer) 1 redis 127.0.0.1:6379> ZADD runoobkey 2 mongodb (integer) 1 redis 127.0.0.1:6379> ZADD runoobkey 3 mysql (integer) 1 redis 127.0.0.1:6379> ZADD runoobkey 3 mysql (integer) 0 redis 127.0.0.1:6379> ZADD runoobkey 4 mysql (integer) 0 redis 127.0.0.1:6379> ZRANGE runoobkey 0 10 WITHSCORES 1) "redis" 2) "1" 3) "mongodb" 4) "2" 5) "mysql" 6) "4"

在以上实例中我们通过命令 ZADD 向 redis 的有序集合中添加了三个值并关联上分数。


Redis 有序集合命令

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

 

序号

命令及描述

1

ZADD key score1 member1 [score2 member2] 

向有序集合添加一个或多个成员,或者更新已存在成员的分数

2

ZCARD key 

获取有序集合的成员数

3

ZCOUNT key min max 

计算在有序集合中指定区间分数的成员数

4

ZINCRBY key increment member 

有序集合中对指定成员的分数加上增量 increment

5

ZINTERSTORE destination numkeys key [key ...] 

计算给定的一个或多个有序集的交集并将结果集存储在新的有序集合 key 中

6

ZLEXCOUNT key min max 

在有序集合中计算指定字典区间内成员数量

7

ZRANGE key start stop [WITHSCORES] 

通过索引区间返回有序集合成指定区间内的成员

8

ZRANGEBYLEX key min max [LIMIT offset count] 

通过字典区间返回有序集合的成员

9

ZRANGEBYSCORE key min max [WITHSCORES] [LIMIT] 

通过分数返回有序集合指定区间内的成员

10

ZRANK key member 

返回有序集合中指定成员的索引

11

ZREM key member [member ...] 

移除有序集合中的一个或多个成员

12

ZREMRANGEBYLEX key min max 

移除有序集合中给定的字典区间的所有成员

13

ZREMRANGEBYRANK key start stop 

移除有序集合中给定的排名区间的所有成员

14

ZREMRANGEBYSCORE key min max 

移除有序集合中给定的分数区间的所有成员

15

ZREVRANGE key start stop [WITHSCORES] 

返回有序集中指定区间内的成员,通过索引,分数从高到底

16

ZREVRANGEBYSCORE key max min [WITHSCORES] 

返回有序集中指定分数区间内的成员,分数从高到低排序

17

ZREVRANK key member 

返回有序集合中指定成员的排名,有序集成员按分数值递减(从大到小)排序

18

ZSCORE key member 

返回有序集中,成员的分数值

19

ZUNIONSTORE destination numkeys key [key ...] 

计算给定的一个或多个有序集的并集,并存储在新的 key 中

20

ZSCAN key cursor [MATCH pattern] [COUNT count] 

迭代有序集合中的元素(包括元素成员和元素分值)

Redis 发布订阅

Redis 发布订阅(pub/sub)是一种消息通信模式:发送者(pub)发送消息,订阅者(sub)接收消息。

Redis 客户端可以订阅任意数量的频道。

下图展示了频道 channel1 , 以及订阅这个频道的三个客户端 —— client2 、 client5 和 client1 之间的关系:

redis的双key redis的key是唯一的吗_数据库

当有新消息通过 PUBLISH 命令发送给频道 channel1 时, 这个消息就会被发送给订阅它的三个客户端:

redis的双key redis的key是唯一的吗_java_02


实例

以下实例演示了发布订阅是如何工作的。在我们实例中我们创建了订阅频道名为 redisChat:

redis 127.0.0.1:6379> SUBSCRIBE redisChat Reading messages... (press Ctrl-C to quit) 1) "subscribe" 2) "redisChat" 3) (integer) 1

现在,我们先重新开启个 redis 客户端,然后在同一个频道 redisChat 发布两次消息,订阅者就能接收到消息。

redis 127.0.0.1:6379> PUBLISH redisChat "Redis is a great caching technique" (integer) 1 redis 127.0.0.1:6379> PUBLISH redisChat "Learn redis by runoob.com" (integer) 1 # 订阅者的客户端会显示如下消息 1) "message" 2) "redisChat" 3) "Redis is a great caching technique" 1) "message" 2) "redisChat" 3) "Learn redis by runoob.com"

Redis 发布订阅命令

下表列出了 redis 发布订阅常用命令:

序号

命令及描述

1

PSUBSCRIBE pattern [pattern ...] 

订阅一个或多个符合给定模式的频道。

2

PUBSUB subcommand [argument [argument ...]] 

查看订阅与发布系统状态。

3

PUBLISH channel message 

将信息发送到指定的频道。

4

PUNSUBSCRIBE [pattern [pattern ...]] 

退订所有给定模式的频道。

5

SUBSCRIBE channel [channel ...] 

订阅给定的一个或多个频道的信息。

6

UNSUBSCRIBE [channel [channel ...]] 

指退订给定的频道。