]> git.saurik.com Git - redis.git/blame - doc/ZrangebyscoreCommand.html
Merge http://github.com/ngmoco/redis
[redis.git] / doc / ZrangebyscoreCommand.html
CommitLineData
8fb13ce8 1
2<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN">
3<html>
4 <head>
5 <link type="text/css" rel="stylesheet" href="style.css" />
6 </head>
7 <body>
8 <div id="page">
9
10 <div id='header'>
11 <a href="index.html">
12 <img style="border:none" alt="Redis Documentation" src="redis.png">
13 </a>
14 </div>
15
16 <div id="pagecontent">
17 <div class="index">
18<!-- This is a (PRE) block. Make sure it's left aligned or your toc title will be off. -->
5d373da9 19<b>ZrangebyscoreCommand: Contents</b><br>&nbsp;&nbsp;<a href="#ZRANGEBYSCORE _key_ _min_ _max_ `[`LIMIT _offset_ _count_`]` (Redis &gt;">ZRANGEBYSCORE _key_ _min_ _max_ `[`LIMIT _offset_ _count_`]` (Redis &gt;</a><br>&nbsp;&nbsp;<a href="#ZRANGEBYSCORE _key_ _min_ _max_ `[`LIMIT _offset_ _count_`]` `[`WITHSCORES`]` (Redis &gt;">ZRANGEBYSCORE _key_ _min_ _max_ `[`LIMIT _offset_ _count_`]` `[`WITHSCORES`]` (Redis &gt;</a><br>&nbsp;&nbsp;&nbsp;&nbsp;<a href="#Exclusive intervals and infinity">Exclusive intervals and infinity</a><br>&nbsp;&nbsp;&nbsp;&nbsp;<a href="#Return value">Return value</a><br>&nbsp;&nbsp;&nbsp;&nbsp;<a href="#Examples">Examples</a>
8fb13ce8 20 </div>
21
22 <h1 class="wikiname">ZrangebyscoreCommand</h1>
23
24 <div class="summary">
25
26 </div>
27
28 <div class="narrow">
29 &iuml;&raquo;&iquest;#sidebar <a href="SortedSetCommandsSidebar.html">SortedSetCommandsSidebar</a><h1><a name="ZRANGEBYSCORE _key_ _min_ _max_ `[`LIMIT _offset_ _count_`]` (Redis &gt;">ZRANGEBYSCORE _key_ _min_ _max_ `[`LIMIT _offset_ _count_`]` (Redis &gt;</a></h1> 1.1) =
ab72b483 30<h1><a name="ZRANGEBYSCORE _key_ _min_ _max_ `[`LIMIT _offset_ _count_`]` `[`WITHSCORES`]` (Redis &gt;">ZRANGEBYSCORE _key_ _min_ _max_ `[`LIMIT _offset_ _count_`]` `[`WITHSCORES`]` (Redis &gt;</a></h1> 1.3.4) =
8fb13ce8 31<i>Time complexity: O(log(N))+O(M) with N being the number of elements in the sorted set and M the number of elements returned by the command, so if M is constant (for instance you always ask for the first ten elements with LIMIT) you can consider it O(log(N))</i><blockquote>Return the all the elements in the sorted set at key with a score between_min_ and <i>max</i> (including elements with score equal to min or max).</blockquote>
32<blockquote>The elements having the same score are returned sorted lexicographically asASCII strings (this follows from a property of Redis sorted sets and does notinvolve further computation).</blockquote>
5d373da9 33<blockquote>Using the optional LIMIT it's possible to get only a range of the matchingelements in an SQL-alike way. Note that if <i>offset</i> is large the commandsneeds to traverse the list for <i>offset</i> elements and this adds up to theO(M) figure.</blockquote><h2><a name="Exclusive intervals and infinity">Exclusive intervals and infinity</a></h2>
34<i>min</i> and <i>max</i> can be -inf and +inf, so that you are not required to know what's the greatest or smallest element in order to take, for instance, elements &quot;up to a given value&quot;.<br/><br/>Also while the interval is for default closed (inclusive) it's possible to specify open intervals prefixing the score with a &quot;(&quot; character, so for instance:
35<pre class="codeblock python" name="code">
36ZRANGEBYSCORE zset (1.3 5
37</pre>
38Will return all the values with score <b>&gt; 1.3 and &lt;= 5</b>, while for instance:
39<pre class="codeblock python python" name="code">
40ZRANGEBYSCORE zset (5 (10
41</pre>
42Will return all the values with score <b>&gt; 5 and &lt; 10</b> (5 and 10 excluded).
8fb13ce8 43<h2><a name="Return value">Return value</a></h2><a href="ReplyTypes.html">Multi bulk reply</a>, specifically a list of elements in the specified score range.
5d373da9 44<h2><a name="Examples">Examples</a></h2>
45<pre class="codeblock python python python" name="code">
46redis&gt; zadd zset 1 foo
47(integer) 1
48redis&gt; zadd zset 2 bar
49(integer) 1
50redis&gt; zadd zset 3 biz
51(integer) 1
52redis&gt; zadd zset 4 foz
53(integer) 1
54redis&gt; zrangebyscore zset -inf +inf
551. &quot;foo&quot;
562. &quot;bar&quot;
573. &quot;biz&quot;
584. &quot;foz&quot;
59redis&gt; zrangebyscore zset 1 2
601. &quot;foo&quot;
612. &quot;bar&quot;
62redis&gt; zrangebyscore zset (1 2
631. &quot;bar&quot;
64redis&gt; zrangebyscore zset (1 (2
65(empty list or set)
66</pre>
8fb13ce8 67 </div>
68
69 </div>
70 </div>
71 </body>
72</html>
73