当前位置:  开发笔记 > 编程语言 > 正文

将数组添加到memcache

如何解决《将数组添加到memcache》经验,为你挑选了1个好方法。

这是我用memcache"存储"mysql查询的代码

$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只存储查询返回的第一行.如何在memcache中的一个键中保存所有20行?



1> origo..:

该声明

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

推荐阅读
围脖上的博博_771
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有