Memcached replace 命令

Memcached replace 命令用于替换已存在的 key(键) 的 value(数据值)。

如果 key 不存在,则替换失败,并且您将获得响应 NOT_STORED。

语法

Memcached replace 命令的基本语法如下所示

replace key flags exptime bytes [noreply]
value

语法中的关键字如下所述

  • key:键值 key-value 结构中的 key,用于查找缓存值。
  • flags:可以包括键值对的整型参数,客户机使用它存储关于键值对的额外信息 。
  • exptime:在缓存中保存键值对的时间长度(以秒为单位,0 表示永远)
  • bytes:在缓存中存储的字节数
  • noreply(可选): 该参数告知服务器不需要返回数据
  • value:存储的值(始终位于第二行)(可直接理解为key-value结构中的value)

命令的输出结果如下所示

STORED
  • STORED表示成功。
  • NOT_STORED表示数据未存储在 Memcached 中。

示例

在下面的示例中,我们使用“key”作为键并将 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) {
      
      // 连接 Memcached 服务
      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("jiyik", 900, "memcached").done);
      
      // 获取值
      System.out.println("Get from Cache:"+mcc.get("jiyik"));
      
      // 替换现有的数据
      System.out.println("Replace cache:"+mcc.replace("jiyik", 900, "redis").done);
      
      // 获取替换之后的值
      System.out.println("Get from Cache:"+mcc.get("jiyik"));
   }
}

在编译和执行程序时,输出以下结果:

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

查看笔记

扫码一下
查看教程更方便