PHP 8.5.0 Beta 1 available for testing

Memcache::add

memcache_add

(PECL memcache >= 0.2.0)

Memcache::add -- memcache_addДобавляет элемент с заданным ключом

Описание

Memcache::add(
    string $key,
    mixed $var,
    int $flag = ?,
    int $expire = ?
): bool
memcache_add(
    Memcache $memcache,
    string $key,
    mixed $var,
    int $flag = ?,
    int $expire = ?
): bool

Метод Memcache::add() записывает элемент var с ключом key, только если сервер ещё не содержит ключ.

Список параметров

key

Ключ, с которым свяжется элемент.

var

Переменная для сохранения. Строковые и числовые значения сохраняются как есть, а остальные типы сериализируются.

flag

При передаче флага MEMCACHE_COMPRESSED элемент сохраняется в сжатом виде. Модуль сжимает элемент средствами библиотеки zlib.

expire

Время жизни элемента. При передаче значения 0 элемент никогда не устаревает. Параметр также принимает метку времени Unix или число секунд, начиная с текущего момента, но тогда числу секунд нельзя превышать значение 2592000, что эквивалентно 30 дням.

Возвращаемые значения

Функция возвращает true, если выполнилась успешно, или false, если возникла ошибка. Метод возвращает false, если такой ключ уже существует, иначе поведение метода Memcache::add() аналогично методу Memcache::set().

Примеры

Пример #1 Пример добавления элемента методом Memcache::add()

<?php

$memcache_obj
= memcache_connect("localhost", 11211);

/* Процедурный API */
memcache_add($memcache_obj, 'var_key', 'test variable', false, 30);

/* Объектно-ориентированный API */
$memcache_obj->add('var_key', 'test variable', false, 30);

?>

Смотрите также

Добавить

Примечания пользователей 5 notes

up
8
vasiliy at hotger dot com
11 years ago
It looks like add() function is truly 100% atomic, and safeadd bicycle mentioned in the other comment is useless. There are few links where developers of Memcahed explained it deeper

http://lists.danga.com/pipermail/memcached/2008-March/006647.html
http://www.serverphorums.com/read.php?9,214222
up
4
Davide Renzi
15 years ago
Race conditions happen on an heavy load server when more than one thread tries to execute memcache_add.
For example if thread A and thread B try to save the same key you can test that sometimes both return TRUE.
To have the right behaviour you can verify that the correct value is in the assigned key:

<?php
function memcache_safeadd(&$memcache_obj, $key, $value, $flag, $expire)
{
if (
memcache_add($memcache_obj, $key, $value, $flag, $expire))
{
return (
$value == memcache_get($memcache_obj, $key));
}
return
FALSE;
}
?>
up
4
ktamas77 at gmail dot com
16 years ago
skeleton of a thread safe updater for an incremental counter:

<?php

$key
= "counter";
$value = $memcache->increment($key, 1);
if (
$value === false) {
// --- read from DB ---
$query = "SELECT value FROM database";
$result = mysql_query($query);
$row = mysql_fetch_assoc($result);
$db_value = $row["value"];
$add_value = $memcache->add($key, $db_value + 1, 0, 0);
if (
$add_value === false) {
$value = $memcache->increment($key, 1)
if (
$value === false) {
error_log ("counter update failed.");
}
} else {
$value = $db_value + 1;
}
}

// --- display counter value ---
echo $value;

?>
up
0
matt
16 years ago
It's also good to note that add will succeed if the key exists but is expired
up
-3
roberto at spadim,com dot br
18 years ago
[c.2007]
if you read source code for MMC_SERIALIZED you will see at line ~1555 that [a line ~1560]
!(is_string,is_long,is_double,is_bool)

[is] serialized and that serialized values are flaged as MMC_SERIALIZED for return (fetch) code unserialize these values again
To Top