非常教程

Redis参考手册

排序集 | Sorted Sets

zrangebyscore

ZRANGEBYSCORE key min max [WITHSCORES] [LIMIT offset count]

自1.0.5起可用。

时间复杂度: O( log(N)+ M),其中 N 是有序集合中元素的数量,M 是返回元素的数量。如果 M 是常量(例如,总是要求使用 LIMIT 的前10个元素),则可以将其视为O( log(N))。

在key中,minmax之间的分数返回排序集合中的所有元素(包括分数等于minmax的元素)。这些元素被认为是从低到高排序。

具有相同分数的元素按照字典顺序返回(这是从 Redis 中的有序集合实现的属性开始的,并且不涉及进一步的计算)。

可选LIMIT参数可用于仅获取匹配元素的范围(与 SELECT LIMIT 偏移量类似,SQL 中的计数类似)。请记住,如果offset很大,则需要offset在获取要返回的元素之前遍历元素的排序集,这可能会增加 O(N)时间复杂度。

可选WITHSCORES参数使命令返回元素及其分数,而不是单独的元素。该选项自 Redis 2.0 开始提供。

独占区间和无穷大

minmax可以是-inf+inf,让你不需要知道的有序集合最高或最低分数来自或达到一定的分数获得的所有元素。

默认情况下,由minmax指定的间隔是关闭的(包括)。可以通过在字符前加上分数来指定开放间隔(独占)(。例如:

ZRANGEBYSCORE zset (1 5

1 < score <= 5 返回所有元素,当在这个时候:

ZRANGEBYSCORE zset (5 (10

将返回5 < score < 10的所有元素(排除5和10)。

返回值

阵列回复:指定分数范围内的元素列表(可选择其分数)。

例子

redis> ZADD myzset 1 "one" (integer) 1 redis> ZADD myzset 2 "two" (integer) 1 redis> ZADD myzset 3 "three" (integer) 1 redis> ZRANGEBYSCORE myzset -inf +inf 1) "one" 2) "two" 3) "three" redis> ZRANGEBYSCORE myzset 1 2 1) "one" 2) "two" redis> ZRANGEBYSCORE myzset (1 2 1) "two" redis> ZRANGEBYSCORE myzset (1 (2 (empty list or set)

模式:元素的加权随机选择

通常使用 ZRANGEBYSCORE 来获得评分是索引整数键的项目范围,但是可以使用该命令做较不明显的事情。

例如,在实现马尔可夫链和其他算法时常见的问题是从一个集合中随机选择一个元素,但是不同的元素可能有不同的权重,这会改变他们被挑选的可能性。

这就是我们如何使用这个命令来安装这样一个算法:

假设你有元素 A ,B 和 C ,权重为1,2和3。你计算权重的总和,即1 + 2 + 3 = 6

此时,您可以使用此算法将所有元素添加到排序集中:

SUM = ELEMENTS.TOTAL_WEIGHT // 6 in this case.
SCORE = 0
FOREACH ELE in ELEMENTS
    SCORE += ELE.weight / SUM
    ZADD KEY SCORE ELE
END

这意味着你设置了:

A to score 0.16
B to score .5
C to score 1

由于这涉及近似值,为了避免 C 设置为0.998而不是1,我们只需修改上述算法以确保最后得分为1(对于读者来说,这留给练习者...)。

在这一点上,每次你想得到一个加权随机元素,只需计算一个介于0和1之间的随机数(这就像rand()在大多数语言中调用一样),所以你可以这样做:

RANDOM_ELE = ZRANGEBYSCORE key RAND() +inf LIMIT 0 1
Redis

Redis 是一个开源的使用 ANSI C 语言编写、遵守 BSD 协议、支持网络、可基于内存亦可持久化的日志型、Key-Value 数据库,并提供多种语言的 API。 它通常被称为数据结构服务器,因为值( value )可以是 字符串( String ), 哈希(Map),列表(list),集合( sets ) 和 有序集合( sorted sets )等类型。

主页 https://redis.io/
源码 https://github.com/antirez/redis
发布版本 4.0.2

Redis目录

1.集合 | Cluster
2.连接 | Connection
3.Geo
4.Hashes
5.HyperLogLog
6.键 | Keys
7.列表 | Lists
8.Pub/Sub
9.脚本 | Scripting
10.服务器 | Server
11.设定 | Sets
12.排序集 | Sorted Sets
13.字符串 | Strings
14.事务 | Transactions
15.Redis Dump 命令
16.Redis DEL 命令
17.Redis 键(key)
18.Redis 命令
19.Redis 配置
20.Redis 简介
21.Redis RANDOMKEY 命令
22.Redis TTL 命令
23.Redis Pttl 命令
24.Redis PERSIST 命令
25.Redis Move 命令
26.Redis PEXPIREAT 命令
27.Redis Keys 命令
28.Redis Expireat 命令
29.Redis Expire 命令
30.Redis EXISTS 命令
31.Redis Mget 命令
32.Redis Getbit 命令
33.Redis Getset 命令
34.Redis Getrange 命令
35.Redis Get 命令
36.Redis SET 命令
37.Redis 字符串(String)
38.Redis Type 命令
39.Redis Renamenx 命令
40.Redis Rename 命令
41.Redis Incrby 命令
42.Redis Incr 命令
43.Redis Psetex 命令
44.Redis Msetnx 命令
45.Redis Mset 命令
46.Redis Strlen 命令
47.Redis Setrange 命令
48.Redis Setnx 命令
49.Redis Setex 命令
50.Redis Setbit 命令
51.Redis Hincrby 命令
52.Redis Hgetall 命令
53.Redis Hget 命令
54.Redis Hexists 命令
55.Redis Hdel 命令
56.Redis 哈希(Hash)
57.Redis Append 命令
58.Redis Decrby 命令
59.Redis Decr 命令
60.Redis Incrbyfloat 命令
61.Redis Blpop 命令
62.Redis 列表(List)
63.Redis Hvals 命令
64.Redis Hsetnx 命令
65.Redis Hset 命令
66.Redis Hmset 命令
67.Redis Hmget 命令
68.Redis Hlen 命令
69.Redis Hkeys 命令
70.Redis Hincrbyfloat 命令
71.Redis Lrem 命令
72.Redis Lrange 命令
73.Redis Lpushx 命令
74.Redis Lpush 命令
75.Redis Lpop 命令
76.Redis Llen 命令
77.Redis Linsert 命令
78.Redis Lindex 命令
79.Redis Brpoplpush 命令
80.Redis Brpop 命令
81.Redis Sdiff 命令
82.Redis Scard 命令
83.Redis Sadd 命令
84.Redis 集合(Set)
85.Redis Rpushx 命令
86.Redis Rpush 命令
87.Redis Rpoplpush 命令
88.Redis Rpop 命令
89.Redis Ltrim 命令
90.Redis Lset 命令
91.Redis Sunion 命令
92.Redis Srem 命令
93.Redis Srandmember 命令
94.Redis Spop 命令
95.Redis Smove 命令
96.Redis Smembers 命令
97.Redis Sismember 命令
98.Redis Sinterstore 命令
99.Redis Sinter 命令
100.Redis Sdiffstore 命令