Memcached::getMulti
(PECL memcached >= 0.1.0)
Memcached::getMulti — Lit plusieurs éléments
Description
Memcached::getMulti() est similaire à la méthode
Memcached::get(), mais au lieu d'un seul élément,
elle sait lire plusieurs éléments spécifiés par le tableau
keys
. Si la variable cas_tokens
est fournie, elle contiendra les CAS de chaque valeur trouvée.
Note:
Contrairement à Memcached::get(), il n'est pas possible de spécifier une fonction de rappel en cas d'absence pour la fonction Memcached::getMulti(), car le protocole de memcache ne fournit pas d'information sur les clés qui n'ont pas été trouvée.
Le paramètre flags
sert à spécifier des options
supplémentaires pour Memcached::getMulti(). Actuellement,
la seule option disponible est
Memcached::GET_PRESERVE_ORDER
qui garantit que les
clés sont retournées dans le même ordre que celui de leur requête.
Liste de paramètres
-
keys
-
Un tableau de clé à lire.
-
cas_tokens
-
La variable où stocker les CAS des éléments trouvés.
-
flags
-
Les options pour cette opération.
Valeurs de retour
Retourne un tableau d'élément lus ou FALSE
si une erreur survient.
Utilisez Memcached::getResultCode()
si nécessaire.
Exemples
Exemple #1 Exemple avec Memcached::append()
<?php
$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);
?>
<?php
$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";
}
?>
L'exemple ci-dessus va afficher quelque chose de similaire à :
foo foo-data bar bar-data baz baz-data lol lol-data kek kek-data zoo
Voir aussi
- Memcached::getMultiByKey() - Lit plusieurs éléments d'un serveur spécifique
- Memcached::get() - Lit un élément
- Memcached::getDelayed() - Lit plusieurs éléments