Memcached-replace-data

提供:Dev Guides
移動先:案内検索

Memcached-データの置換

Memcached replace コマンドは、既存のキーの値を置き換えるために使用されます。 キーが存在しない場合、NOT_STOREDを出力します。

構文

Memcached replace コマンドの基本的な構文は以下のとおりです-

replace key flags exptime bytes [noreply]
value

構文のキーワードは以下のとおりです-

  • key -データの保存とMemcachedからの取得に使用されるキーの名前です。
  • フラグ-これは、ユーザーが提供したデータとともにサーバーが保存する32ビットの符号なし整数であり、アイテムが取得されるとデータとともに戻ります。
  • exptime -秒単位の有効期限です。 0は遅延がないことを意味します。 exptimeが30日を超える場合、Memcachedはそれを有効期限のUNIXタイムスタンプとして使用します。
  • バイト-それは格納する必要があるデータブロック内のバイト数です。 これは、Memcachedに保存する必要があるデータの長さです。
  • * noreply(オプション)*-サーバーに何も送信しないように通知するパラメーターです 応答。
  • -保存する必要があるデータです。 上記のオプションを使用してコマンドを実行した後、データを新しい行に渡す必要があります。

出力

コマンドの出力は次のようになります-

STORED
  • STORED は成功を示します。
  • NOT_STORED は、データがMemcachedに保存されないことを示します。

次の例では、「キー」をキーとして使用し、memcachedを有効期限900秒で保存します。 この後、同じキーが値「redis」に置き換えられます。

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

Javaアプリケーションを使用したデータの置換

Memcachedサーバーのデータを置き換えるには、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("finddevguides", 900, "memcached").done);

     //Get value from cache
      System.out.println("Get from Cache:"+mcc.get("finddevguides"));

     //now replace the existing data
      System.out.println("Replace cache:"+mcc.replace("finddevguides", 900, "redis").done);

     //get the updated data
      System.out.println("Get from Cache:"+mcc.get("finddevguides"));
   }
}

出力

プログラムをコンパイルして実行すると、次の出力が表示されます-

Connection to server successfully
set status:true
Get from Cache:memcached
Replace cache:true
Get from Cache:redis