Добавить массив в memcache - PullRequest
       4

Добавить массив в memcache

2 голосов
/ 20 января 2011

Вот мой код для «хранения» запросов mysql с помощью memcache

$mem = new Memcache;
$mem->connect('127.0.0.1', 11211);

$query = "SELECT * FROM tbl limit 0,20 ";
$key = md5($query);

$get_data = $memcache->get($key);

if($get_data) {
 echo 'Data Pulled From Cache';
} else {
   $res = mysql_fetch_array(mysql_query($query));
   $memcache->set($key, $res, TRUE, 3600); 
}

Проблема заключается в том, что memcache хранит только первую строку, возвращаемую запросом.Как сохранить все 20 строк в пределах одного ключа в memcache?

Ответы [ 2 ]

7 голосов
/ 20 января 2011

Оператор

$ res = mysql_fetch_array (mysql_query ($ query);

извлекает только ОДНУЮ строку из результата запроса.

Попробуйте что-то подобное, чтобы получитьВесь результат перед сохранением в кеше:

$res = array();
$qres = mysql_query($query);
while($a = mysql_fetch_array($qres, MYSQL_ASSOC))
  $res[] = $a;
mysql_free_result($res);

$memcache->set($key, $res, TRUE, 3600);
1 голос
/ 20 января 2011

Вместо

$res = mysql_fetch_array(mysql_query($query));
$memcache->set($key, $res, TRUE, 3600);

используйте mysql_fetch_array() с while, отметьте

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...