memcached的prepend命令用于添加一些数据到现有的键(key)。数据将存储在键的现有的数据之前。
memcached的prepend命令的基本语法如下所示:
prepend key flags exptime bytes [noreply] value
以上关键字的含义,如下图所示:
key 是通过被存储在memcached的数据并从memcached获取键(key)的名称。
flags 是32位无符号整数,该项目被检索时用的数据(由用户提供),并沿数据返回服务器存储。
exptime 以秒为过期时间,0表示没有延迟,如果exptime大于30天,memcached将使用它作为unix时间戳过期。
bytes 是在数据块中,需要被存储的字节数。基本上,这是一个需要存储在memcached的数据的长度。
noreply (optional) 参数告知服务器不发送回复
value 是一个需要存储的数据。数据需要将通过在新的一行后,执行命令上述选项。
上述命令的输出如下所示:
stored
stored 表示成功。
not_stored, 如果key不存在于memcached服务器。
client_error, 如果有一些错误。
prepend tutorials 0 900 5 redis not_stored set tutorials 0 900 9 memcached stored get tutorials value tutorials 0 14 memcached end prepend tutorials 0 900 5 redis stored get tutorials value tutorials 0 14 redismemcached end
在上面的例子中,我们将一些数据添加一个键,它不存在,memcached返回not_stored ,之后我们已经建立一个键和预先添加数据到其中。
要预先设置数据memcached服务器,需要使用memcached的prepend方法。
import net.spy.memcached.memcachedclient; public class memcachedjava { public static void main(string[] args) { //connecting to memcached server on localhost memcachedclient mcc = new memcachedclient(new inetsocketaddress("127.0.0.1", 11211)); system.out.println("connection to server sucessfully"); system.out.println("set status:"+mcc.set("h3", 900, "memcached").isdone()); //get value from cache system.out.println("get from cache:"+mcc.get("h3")); // now append some data into existing key system.out.println("prepend to cache:"+mcc.prepend("h3", "redis").isdone()); // get the updated key system.out.println("get from cache:"+mcc.get("h3")); } }
当上述程序编译和运行,它提供了以下的输出:
connection to server successfully set status:true get from cache:memcached prepend to cache:true get from cache:redismemcached