(PECL memcached >= 0.1.0)
Memcached::getMulti — 複数のアイテムを取得する
Memcached::getMulti() は
Memcached::get() と似ていますが、ひとつのキーのアイテムを取得するのではなく
keys
配列で指定したキー群から複数のアイテムを取得します。
注意:
v3.0 より前のバージョンでは、二番目のパラメータ
&cas_tokens
が存在して、見つかったアイテムの CAS トークンが書き込まれるようになっていました。 この&cas_tokens
パラメータは memcached 拡張モジュールの v3.0 で削除されました。 その代わりに追加されたのがMemcached::GET_EXTENDED
フラグで、 これをflags
に指定すれば CAS トークンを得られます。
flags
パラメータを使用して、
Memcached::getMulti()
用の追加のオプションを設定します。
Memcached::GET_PRESERVE_ORDER
は、要求したのと同じ順番でキーが返されることを保証します。
Memcached::GET_EXTENDED
は、CAS トークンも含めて返すようにします。
keys
取得したいキーの配列。
flags
取得操作のオプション。
見つかったアイテムの配列、失敗した場合に false
を返します。
必要に応じて Memcached::getResultCode() を使用しましょう。
バージョン | 説明 |
---|---|
PECL memcached 3.0.0 |
&cas_tokens パラメータが削除されました。
Memcached::GET_EXTENDED が追加され、これをフラグとして渡すと CAS トークンも取得するようになりました。
|
例1 Memcached::getMulti() example for Memcached v3
<?php
// Valid for v3 of the extension
$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() example for Memcached v1 and v2
<?php
// Valid for v1 and v2 of the extension
$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 v3 用の Memcached::GET_PRESERVE_ORDER
の例
<?php
// Valid for v3 of the extension
$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 v1 および v2 用の Memcached::GET_PRESERVE_ORDER
の例
<?php
// Valid for v1 and v2 of the extension
$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