发布于 2015-06-28 02:21:13 | 395 次阅读 | 评论: 1 | 来源: 网络整理
Memcached的add命令用于为一个值(value)设置为一个新的键(key)。如果键(key)已经存在,那么它输出NOT_STORED。
memcached 的 Add命令的基本语法如下所示:
add 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, 如果数据没有被存储在memcached。
add key 0 900 9
memcached
STORED
get key
VALUE key 0 9
memcached
END
在上面的例子中,我们已经使用key作为memcached的键在其900秒失效时间内添加值。
add key 0 900 5
redis
NOT_STORED
要在memcached服务器中添加数据,需要使用memcached的add方法。
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("add status:"+mcc.add("phperz", 900, "redis").done);
System.out.println("add status:"+mcc.add("tp", 900, "redis").done);
//Get value from cache
System.out.println("Get from Cache tp:"+mcc.get("tp"));
}
}
当上述程序编译和运行,它提供了以下的输出:
Connection to server successfully
add status:false
add status:true
Get from Cache tp:redis
add命令是仅当缓存中不存在键时,add 命令才会向缓存中添加一个键值对。如果缓存中已经存在键,则之前的值将仍然保持相同,并且您将获得响应 NOT_STORED。