Memcached的prepend命令用于添加一些數(shù)據(jù)到現(xiàn)有的鍵(key)。數(shù)據(jù)將存儲(chǔ)在鍵的現(xiàn)有的數(shù)據(jù)之前。
memcached的prepend命令的基本語(yǔ)法如下所示:
prepend key flags exptime bytes [noreply] value
以上關(guān)鍵字的含義,如下圖所示:
key 是通過(guò)被存儲(chǔ)在Memcached的數(shù)據(jù)并從memcached獲取鍵(key)的名稱(chēng)。
flags 是32位無(wú)符號(hào)整數(shù),該項(xiàng)目被檢索時(shí)用的數(shù)據(jù)(由用戶(hù)提供),并沿?cái)?shù)據(jù)返回服務(wù)器存儲(chǔ)。
exptime 以秒為過(guò)期時(shí)間,0表示沒(méi)有延遲,如果exptime大于30天,Memcached將使用它作為UNIX時(shí)間戳過(guò)期。
bytes 是在數(shù)據(jù)塊中,需要被存儲(chǔ)的字節(jié)數(shù)?;旧希@是一個(gè)需要存儲(chǔ)在memcached的數(shù)據(jù)的長(zhǎng)度。
noreply (optional) 參數(shù)告知服務(wù)器不發(fā)送回復(fù)
value 是一個(gè)需要存儲(chǔ)的數(shù)據(jù)。數(shù)據(jù)需要將通過(guò)在新的一行后,執(zhí)行命令上述選項(xiàng)。
上述命令的輸出如下所示:
STORED
STORED 表示成功。
NOT_STORED, 如果key不存在于memcached服務(wù)器。
CLIENT_ERROR, 如果有一些錯(cuò)誤。
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
在上面的例子中,我們將一些數(shù)據(jù)添加一個(gè)鍵,它不存在,memcached返回NOT_STORED ,之后我們已經(jīng)建立一個(gè)鍵和預(yù)先添加數(shù)據(jù)到其中。
要預(yù)先設(shè)置數(shù)據(jù)memcached服務(wù)器,需要使用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("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("Prepend to cache:"+mcc.prepend("yiibai", "redis").isDone());
// get the updated key
System.out.println("Get from Cache:"+mcc.get("yiibai"));
}
}
當(dāng)上述程序編譯和運(yùn)行,它提供了以下的輸出:
Connection to server successfully set status:true Get from Cache:memcached Prepend to cache:true Get from Cache:redismemcached