Memcached::getMulti

(PECL memcached >= 0.1.0)

Memcached::getMulti檢索多個元素

說明

public Memcached::getMulti(array $keys, int $flags = ?): mixed

Memcached::getMulti()Memcached::get() 類似,但是這個方法用來檢索 keys 數(shù)組指定的多個 key 對應(yīng)的元素。

注意:

在 v3.0 之前,使用的第二個參數(shù)是 &cas_tokens。 它會填充進(jìn)元素的 CAS token 值。 在本擴(kuò)展里,&cas_tokens 參數(shù)在 v3.0 中已經(jīng)移除。 它被新的附加選項(flag) Memcached::GET_EXTENDED 代替,需要在 flags 值里使用。

flags參數(shù)可以用做指定Memcached::getMulti()的附加選項。 當(dāng)前,僅可以指定為Memcached::GET_PRESERVE_ORDER以保證返回的key的順序和請求時一致。 Memcached::GET_EXTENDED 可以確保同時返回了 CAS token 信息。

參數(shù)

keys

要檢索的key的數(shù)組。

flags

Get 操作的附加選項。

返回值

返回檢索到的元素的數(shù)組 或者在失敗時返回 false. 如需要則使用 Memcached::getResultCode()。

范例

示例 #1 Memcached::getMulti() 的 Memcached v3 示例

<?php
// 擴(kuò)展版本 v3 有效

$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() 的 Memcached v1 和 v2 示例

<?php
// 僅在擴(kuò)展版本 v1 和 v2 中有效

$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 的 Memcached v3 示例

<?php
//  v3 擴(kuò)展有效

$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($data3600);

$keys array_keys($data);
$keys[] = 'zoo';
$got $m->getMulti($keysMemcached::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 的 Memcached v1 和 v2 示例

<?php
// 在擴(kuò)展版本 v1 和 v2  中有效

$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($data3600);

$null null;
$keys array_keys($data);
$keys[] = 'zoo';
$got $m->getMulti($keys$nullMemcached::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 

更新日志

版本 說明
3.0.0 移出參數(shù) &cas_tokens。 添加 Memcached::GET_EXTENDED,當(dāng)需要獲取 CAS token 信息時,傳入 flag 中。

參見