Memcached - 替换数据



Memcached 的 replace 命令用于替换现有键的值。如果键不存在,则输出 NOT_STORED。

语法

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

replace key flags exptime bytes [noreply]
value

语法中的关键字如下所述:

  • key - 它是存储和检索 Memcached 中数据的键的名称。

  • flags - 它是服务器与用户提供的数据一起存储的 32 位无符号整数,并在检索项目时与数据一起返回。

  • exptime - 以秒为单位的过期时间。0 表示没有延迟。如果 exptime 超过 30 天,Memcached 将其用作 UNIX 时间戳以进行过期。

  • bytes - 需要存储的数据块中的字节数。这是需要存储在 Memcached 中的数据的长度。

  • noreply (可选) - 它是一个参数,通知服务器不要发送任何回复。

  • 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) {
      
      // 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("tutorialspoint", 900, "memcached").done);
      
      // Get value from cache
      System.out.println("Get from Cache:"+mcc.get("tutorialspoint"));
      
      // now replace the existing data
      System.out.println("Replace cache:"+mcc.replace("tutorialspoint", 900, "redis").done);
      
      // get the updated data
      System.out.println("Get from Cache:"+mcc.get("tutorialspoint"));
   }
}

输出

编译并执行程序后,您将看到以下输出:

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