Memcached的replace 命令用來替換現(xiàn)有鍵的值。如果該鍵不存在,那么它輸出NOT_STORED
memcached的replace命令的基本語法如下所示:
replace key flags exptime bytes [noreply] value
以上關(guān)鍵字的含義,如下圖所示:
key 是通過被存儲在Memcached的數(shù)據(jù)并從memcached獲取鍵(key)的名稱。
flags 是32位無符號整數(shù),該項目被檢索時用的數(shù)據(jù)(由用戶提供),并沿數(shù)據(jù)返回服務(wù)器存儲。
exptime 以秒為過期時間,0表示沒有延遲,如果exptime大于30天,Memcached將使用它作為UNIX時間戳過期。
bytes 是在數(shù)據(jù)塊中,需要被存儲的字節(jié)數(shù)?;旧希@是一個需要存儲在memcached的數(shù)據(jù)的長度。
noreply (optional) 參數(shù)告知服務(wù)器不發(fā)送回復(fù)
value 是一個需要存儲的數(shù)據(jù)。數(shù)據(jù)需要將通過在新的一行后,執(zhí)行命令上述選項。
上述命令的輸出如下所示:
STORED
STORED 用來表示成功。
NOT_STORED, 如果數(shù)據(jù)沒有被存儲在memcached。
add key 0 900 9 memcached STORED get key VALUE key 0 9 memcached END replace key 0 900 5 redis get key VALUE key 0 5 redis END
在上面的例子中,我們已經(jīng)使用key作為鍵,并存儲memcached在900秒失效時間之前。同樣的鍵替換值為Redis。
要替換memcached服務(wù)器的數(shù)據(jù),則需要使用Memcached的replace方法。
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").done);
//Get value from cache
System.out.println("Get from Cache:"+mcc.get("yiibai"));
//now replace the existing data
System.out.println("Replace cache:"+mcc.replace("yiibai", 900, "redis").done);
//get the updated data
System.out.println("Get from Cache:"+mcc.get("yiibai"));
}
}
當(dāng)上述程序編譯和運(yùn)行,它提供了以下的輸出:
Connection to server successfully set status:true Get from Cache:memcached Replace cache:true Get from Cache:redis