- Memcached 基础
- Memcached - 首页
- Memcached - 概述
- Memcached - 环境
- Memcached - 连接
- Memcached 存储命令
- Memcached - 设置数据
- Memcached - 添加数据
- Memcached - 替换数据
- Memcached - 追加数据
- Memcached - 预置数据
- Memcached - CAS
- Memcached 检索命令
- Memcached - 获取数据
- Memcached - 获取 CAS 数据
- Memcached - 删除键
- Memcached - 删除数据
- Memcached - 自增/自减
- Memcached 统计命令
- Memcached - 统计信息
- Memcached - 统计项目
- Memcached - 统计内存块
- Memcached - 统计大小
- Memcached - 清除数据
- Memcached 有用资源
- Memcached - 快速指南
- Memcached - 有用资源
- Memcached - 讨论
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
广告