Memcached - 预置数据



Memcached 的 **prepend** 命令用于在现有键中添加一些数据。数据存储在键的现有数据之前。

语法

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

prepend 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 服务器中不存在。

  • **CLIENT_ERROR** 表示错误。

示例

在以下示例中,我们在不存在的键中添加了一些数据。因此,Memcached 返回 **NOT_STORED**。在此之后,我们设置一个键并在其中预置数据。

prepend tutorials 0 900 5
redis
NOT_STORED
set tutorials 0 900 9
memcached
STORED
get tutorials
VALUE tutorials 0 14
memcached
END
prepend tutorials 0 900 5
redis
STORED
get tutorials
VALUE tutorials 0 14
redismemcached
END

使用 Java 应用程序预置数据

要在 Memcached 服务器中预置数据,您需要使用 Memcached 的 **prepend** 方法。

示例

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 successful");
      System.out.println("set status:"+mcc.set("tutorialspoint", 900, "memcached").isDone());
      
      // Get value from cache
      System.out.println("Get from Cache:"+mcc.get("tutorialspoint"));
      
      // now append some data into existing key
      System.out.println("Prepend to cache:"+mcc.prepend("tutorialspoint", "redis").isDone());
      
      // get the updated key
      System.out.println("Get from Cache:"+mcc.get("tutorialspoint"));
   }
}

输出

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

Connection to server successful
set status:true
Get from Cache:memcached
Prepend to cache:true
Get from Cache:redismemcached
广告