Memcached::getMulti

(PECL memcached >= 0.1.0)

Memcached::getMultiRecupera vários itens

Descrição

public Memcached::getMulti(array $keys, int $get_flags = 0): array|false

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 flag Memcached::GET_EXTENDED que precisa ser usado como valor para get_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_EXTENDEDfoi 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