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