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