Memcached添加數據
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
使用Java應用程序添加數據
要在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("yiibai", 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