Memcached::getMulti
(PECL memcached >= 0.1.0)
Memcached::getMulti — Получает несколько записей
Описание
Memcached::getMulti() работает аналогично методу
Memcached::get(), но вместо одной записи
получает несколько, ключи которых были переданы в массиве
keys
.
Замечание:
До версии 3.0 использовался второй аргумент
&cas_tokens
. Он заполнялся значениями токена CAS для найденых записей. Параметр&cas_tokens
был удален в версии 3.0. Он был заменен новым флагомMemcached::GET_EXTENDED
, который указывается в параметреflags
.
Параметр flags
может использоваться для указания дополнительных
настроек для метода Memcached::getMulti(). На данный момент
поддерживаются, только следующие настройки:
Memcached::GET_PRESERVE_ORDER
гарантирует что записи будут
возвращены в том же порядке, что и были запрошены.
Memcached::GET_EXTENDED
ведет к тому, что также будут
извлечены токены CAS.
Список параметров
-
keys
-
Массив ключей для запроса.
-
flags
-
Флаги для операции получения записей.
Возвращаемые значения
Возвращает массив найденных записей или false
в случае возникновения ошибки.
Используйте при необходимости Memcached::getResultCode().
Примеры
Пример #1 Пример использования Memcached::getMulti() версии 3
<?php
// Работает с версией расширения 3
$m = new Memcached();
$m->addServer('localhost', 11211);
$items = array(
'key1' => 'value1',
'key2' => 'value2',
'key3' => 'value3'
);
$m->setMulti($items);
$result = $m->getMulti(array('key1', 'key3', 'badkey'));
var_dump($result);
?>
Результатом выполнения данного примера будет что-то подобное:
array(2) { ["key1"]=> string(6) "value1" ["key3"]=> string(6) "value3" }
Пример #2 Пример использования Memcached::getMulti() версий 1 и 2
<?php
// Работает с версиями расширения 1 и 2
$m = new Memcached();
$m->addServer('localhost', 11211);
$items = array(
'key1' => 'value1',
'key2' => 'value2',
'key3' => 'value3'
);
$m->setMulti($items);
$result = $m->getMulti(array('key1', 'key3', 'badkey'), $cas);
var_dump($result, $cas);
?>
Результатом выполнения данного примера будет что-то подобное:
array(2) { ["key1"]=> string(6) "value1" ["key3"]=> string(6) "value3" } array(2) { ["key1"]=> float(2360) ["key3"]=> float(2362) }
Пример #3 Пример использования Memcached::GET_PRESERVE_ORDER
с версией 3
<?php
// Работает с версией расширения 3
$m = new Memcached();
$m->addServer('localhost', 11211);
$data = array(
'foo' => 'foo-data',
'bar' => 'bar-data',
'baz' => 'baz-data',
'lol' => 'lol-data',
'kek' => 'kek-data',
);
$m->setMulti($data, 3600);
$keys = array_keys($data);
$keys[] = 'zoo';
$got = $m->getMulti($keys, Memcached::GET_PRESERVE_ORDER);
foreach ($got as $k => $v) {
echo "$k $v\n";
}
?>
Результатом выполнения данного примера будет что-то подобное:
foo foo-data bar bar-data baz baz-data lol lol-data kek kek-data zoo
Пример #4 Пример использования Memcached::GET_PRESERVE_ORDER
с версией 1 и 2
<?php
// Работает с версиями расширения 1 и 2
$m = new Memcached();
$m->addServer('localhost', 11211);
$data = array(
'foo' => 'foo-data',
'bar' => 'bar-data',
'baz' => 'baz-data',
'lol' => 'lol-data',
'kek' => 'kek-data',
);
$m->setMulti($data, 3600);
$null = null;
$keys = array_keys($data);
$keys[] = 'zoo';
$got = $m->getMulti($keys, $null, Memcached::GET_PRESERVE_ORDER);
foreach ($got as $k => $v) {
echo "$k $v\n";
}
?>
Результатом выполнения данного примера будет что-то подобное:
foo foo-data bar bar-data baz baz-data lol lol-data kek kek-data zoo
Список изменений
Версия | Описание |
---|---|
PECL memcached 3.0.0 |
Удален параметр &cas_tokens .
Добавлена константа Memcached::GET_EXTENDED для
возврата токенов CAS.
|
Смотрите также
- Memcached::getMultiByKey() - Получает несколько записей с указанного сервера
- Memcached::get() - Получение записи
- Memcached::getDelayed() - Запрашивает несколько записей