- Memcached 基础
- Memcached - 首页
- Memcached - 概述
- Memcached - 环境
- Memcached - 连接
- Memcached 存储命令
- Memcached - 设置数据
- Memcached - 添加数据
- Memcached - 替换数据
- Memcached - 追加数据
- Memcached - 前置数据
- Memcached - CAS
- Memcached 获取命令
- Memcached - 获取数据
- Memcached - 获取CAS数据
- Memcached - 删除键
- Memcached - 删除数据
- Memcached - 自增/自减
- Memcached 统计命令
- Memcached - 统计
- Memcached - 项目统计
- Memcached - Slab 统计
- Memcached - 大小统计
- Memcached - 清除数据
- Memcached 有用资源
- Memcached - 快速指南
- Memcached - 有用资源
- Memcached - 讨论
Memcached - 追加数据
Memcached 的 **append** 命令用于向现有键添加一些数据。数据存储在键的现有数据之后。
语法
Memcached **append** 命令的基本语法如下所示:
append 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**。在此之后,我们设置一个键并向其中追加数据。
append tutorials 0 900 5 redis NOT_STORED set tutorials 0 900 9 memcached STORED get tutorials VALUE tutorials 0 14 memcached END append tutorials 0 900 5 redis STORED get tutorials VALUE tutorials 0 14 memcachedredis END
使用 Java 应用程序追加数据
要在 Memcached 服务器中追加数据,您需要使用 Memcached 的 **append** 方法。
示例
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("Append to cache:"+mcc.append("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 Append to cache:true Get from Cache:memcachedredis
广告