memcached的append 命令是用来添加一些数据到现有键(key)。数据是存储在键的现有数据之后。
memcached的append命令的基本语法如下所示:
append 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, 如果有一些错误。
append tutorials 0 900 5 redis NOT_STORED set tutorials 0 900 9 memcached STORED get tutorials VALUE tutorials 0 14 memcached END append tutorials 0 900 5 redis STORED get tutorials VALUE tutorials 0 14 memcachedredis END
在上面的例子中,我们添加一些数据在键中,如果它不存在,则 memcached 返回NOT_STORED,我们已经建立一个键并附加数据到其中。
附加数据到memcached服务器,需要使用memcached的append方法。
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("yiibai", 900, "memcached").isDone()); //Get value from cache System.out.println("Get from Cache:"+mcc.get("yiibai")); // now append some data into existing key System.out.println("Append to cache:"+mcc.append("yiibai", "redis").isDone()); // get the updated key System.out.println("Get from Cache:"+mcc.get("yiibai")); } }
当上述程序编译和运行,它提供了以下的输出:
Connection to server successfully set status:true Get from Cache:memcached Append to cache:true Get from Cache:memcachedredis