]> git.saurik.com Git - redis.git/blobdiff - doc/SetrangeCommand.html
no more html documentation
[redis.git] / doc / SetrangeCommand.html
diff --git a/doc/SetrangeCommand.html b/doc/SetrangeCommand.html
deleted file mode 100644 (file)
index 1bd70b4..0000000
+++ /dev/null
@@ -1,58 +0,0 @@
-
-<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN">
-<html>
-    <head>
-        <link type="text/css" rel="stylesheet" href="style.css" />
-    </head>
-    <body>
-        <div id="page">
-        
-            <div id='header'>
-            <a href="index.html">
-            <img style="border:none" alt="Redis Documentation" src="redis.png">
-            </a>
-            </div>
-        
-            <div id="pagecontent">
-                <div class="index">
-<!-- This is a (PRE) block.  Make sure it's left aligned or your toc title will be off. -->
-<b>SetrangeCommand: Contents</b><br>&nbsp;&nbsp;<a href="#SETRANGE _key_ _offset_ _value_ (Redis &gt;">SETRANGE _key_ _offset_ _value_ (Redis &gt;</a><br>&nbsp;&nbsp;&nbsp;&nbsp;<a href="#Examples">Examples</a><br>&nbsp;&nbsp;&nbsp;&nbsp;<a href="#Patterns">Patterns</a><br>&nbsp;&nbsp;&nbsp;&nbsp;<a href="#Return value">Return value</a>
-                </div>
-                
-                <h1 class="wikiname">SetrangeCommand</h1>
-
-                <div class="summary">
-                    
-                </div>
-
-                <div class="narrow">
-                    &iuml;&raquo;&iquest;#sidebar <a href="StringCommandsSidebar.html">StringCommandsSidebar</a><h1><a name="SETRANGE _key_ _offset_ _value_ (Redis &gt;">SETRANGE _key_ _offset_ _value_ (Redis &gt;</a></h1> 2.1.8) =
-<i>Time complexity: O(1) not counting the time taken to copy the new string in place, as usually this string is small so the amoritzed time is O(1). Otheriwse O(M) with M being the length of the value argument</i><blockquote>Overwrites part of a string at <i>key</i> starting at the specified offset,for all the length of <i>value</i>.If the offset is over the old length of the string, the string is paddedwith zero bytes until needed. Non existing keys are considered likealready containing an empty string.</blockquote>
-<h2><a name="Examples">Examples</a></h2>First example, basic usage setting a range.<br/><br/><pre class="codeblock python" name="code">
-redis&gt; set foo &quot;Hello World&quot;
-OK
-redis&gt; setrange foo 6 &quot;Redis&quot;
-(integer) 11
-redis&gt; get foo
-&quot;Hello Redis&quot;
-</pre>Example of the zero padding behavior.<br/><br/><pre class="codeblock python python" name="code">
-redis&gt; del foo
-(integer) 1
-redis&gt; setrange foo 10 bar
-(integer) 13
-redis&gt; get foo
-&quot;\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00bar&quot;
-</pre>Note that the maximum offset that you can set is 536870911 as Redis Strings are limited to 512 megabytes. You can still create longer arrays of values using multiple keys.<br/><br/><b>Warning</b>: When setting the last possible byte and the string value stored at <i>key</i> does not yet hold a string value, or holds a small string value, Redis needs to allocate all intermediate memory which can block the server for some time.
-On a 2010 Macbook Pro, setting byte number 536870911 (512MB allocation) takes ~300ms,
-setting byte number 134217728 (128MB allocation) takes ~80ms,
-setting bit number 33554432 (32MB allocation) takes ~30ms and
-setting bit number 8388608 (8MB allocation) takes ~8ms.
-Note that once this first allocation is done, subsequent calls to SETRANGE for the same <i>key</i> will not have the allocation overhead.<h2><a name="Patterns">Patterns</a></h2>Thanks to SETRANGE and the analogous GETRANGE command you can use Redis strings as a linear array of memory with O(1) random access. This is a very fast and efficient storage in many real world use cases.<h2><a name="Return value">Return value</a></h2><a href="ReplyTypes.html">Integer reply</a>, specifically: the length of the string after it was modified by the command.
-
-                </div>
-        
-            </div>
-        </div>
-    </body>
-</html>
-