Memcached 专题
您的位置:database > Memcached专题 > Memcached替换/Replace数据
Memcached替换/Replace数据
作者:--    发布时间:2019-11-20

memcached的replace 命令用来替换现有键的值。如果该键不存在,那么它输出not_stored

语法

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

replace 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
replace key 0 900 5
redis
get key
value key 0 5
redis
end

在上面的例子中,我们已经使用key作为键,并存储memcached在900秒失效时间之前。同样的键替换值为redis。

使用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("h3", 900, "memcached").done);
      //get value from cache
      system.out.println("get from cache:"+mcc.get("h3"));
      //now replace the existing data
      system.out.println("replace cache:"+mcc.replace("h3", 900, "redis").done);
      //get the updated data
      system.out.println("get from cache:"+mcc.get("h3"));
   }
}

输出

当上述程序编译和运行,它提供了以下的输出:

connection to server successfully
set status:true
get from cache:memcached
replace cache:true
get from cache:redis

网站声明:
本站部分内容来自网络,如您发现本站内容
侵害到您的利益,请联系本站管理员处理。
联系站长
373515719@qq.com
关于本站:
编程参考手册