Memcached::getMulti
(PECL memcached >= 0.1.0)
Memcached::getMulti — Recupera vários itens
Descrição
Memcached::getMulti() é semelhante a
Memcached::get(), mas em vez de um único item de key,
ele recupera vários itens cujas keys são especificadas no
array keys
.
Note:
Antes da versão 3.0, um segundo argumento
&cas_tokens
estava em uso. Ele foi preenchido com os valores de token CAS para os itens encontrados. O parâmetro&cas_tokens
foi removido na v3.0 da extensão. Ele foi substituído por uma nova flagMemcached::GET_EXTENDED
que precisa ser usado como valor paraget_flags
.
O parâmetro get_flags
pode ser usado para especificar
opções adicionais para Memcached::getMulti().
Memcached::GET_PRESERVE_ORDER
garante que as
keys sejam retornadas na mesma ordem em que foram solicitadas.
Memcached::GET_EXTENDED
garante que os
tokens CAS também sejam buscados.
Parâmetros
keys
-
Array de keys a ser recuperado.
get_flags
-
As flags para a operação get.
Valor Retornado
Retorna o array de itens encontrados ou false
em caso de falha.
Use Memcached::getResultCode() se necessário.
Registro de Alterações
Versão | Descrição |
---|---|
PECL memcached 3.0.0 |
O parâmetro &cas_tokens foi removido.
O Memcached::GET_EXTENDED foi adicionado e quando passado como flag garante que os tokens CAS sejam buscados.
|
Exemplos
Example #1 Memcached::getMulti() exemplo para Memcached v3
<?php
// Válido para v3 da extensão
$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);
?>
O exemplo acima produzirá algo semelhante a:
array(2) { ["key1"]=> string(6) "value1" ["key3"]=> string(6) "value3" }
Example #2 Memcached::getMulti() exemplo para Memcached v1 e v2
<?php
// Válido para v1 e v2 da extensão
$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);
?>
O exemplo acima produzirá algo semelhante a:
array(2) { ["key1"]=> string(6) "value1" ["key3"]=> string(6) "value3" } array(2) { ["key1"]=> float(2360) ["key3"]=> float(2362) }
Example #3 Memcached::GET_PRESERVE_ORDER
exemplo para Memcached v3
<?php
// Válido para v3 da extensão
$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";
}
?>
O exemplo acima produzirá algo semelhante a:
foo foo-data bar bar-data baz baz-data lol lol-data kek kek-data zoo
Example #4 Memcached::GET_PRESERVE_ORDER
exemplo para Memcached v1 e v2
<?php
// Válido para v1 e v2 da extensão
$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";
}
?>
O exemplo acima produzirá algo semelhante a:
foo foo-data bar bar-data baz baz-data lol lol-data kek kek-data zoo
Veja Também
- Memcached::getMultiByKey() - Recupere vários itens de um servidor específico
- Memcached::get() - Recupera um item
- Memcached::getDelayed() - Solicita vários itens