如何在PHP中Memcached类实现内存缓存?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。
具体实现方法如下:
<?PHP class MemcacheModel { private $mc = null; /** * 构造方法,用于添加服务器并创建memcahced对象 */ function __construct(){ $params = func_get_args(); $mc = new Memcache; //如果有多个memcache服务器 if( count($params) > 1){ foreach ($params as $v){ call_user_func_array(array($mc, 'addServer'), $v); } //如果只有一个memcache服务器 } else { call_user_func_array(array($mc, 'addServer'), $params[0]); } $this->mc=$mc; } /** * 获取memcached对象 * @return object memcached对象 */ function getMem(){ return $this->mc; } /** * 检查mem是否连接成功 * @return bool 连接成功返回true,否则返回false */ function mem_connect_error(){ $stats=$this->mc->getStats(); if(emptyempty($stats)){ return false; }else{ return true; } } private function addKey($tabName, $key){ $keys=$this->mc->get($tabName); if(emptyempty($keys)){ $keys=array(); } //如果key不存在,就添加一个 if(!in_array($key, $keys)) { $keys[]=$key; //将新的key添加到本表的keys中 $this->mc->set($tabName, $keys, MEMCACHE_COMPRESSED, 0); return true; //不存在返回true }else{ return false; //存在返回false } } /** * 向memcache中添加数据 * @param string $tabName 需要缓存数据表的表名 * @param string $sql 使用sql作为memcache的key * @param mixed $data 需要缓存的数据 */ function addCache($tabName, $sql, $data){ $key=md5($sql); //如果不存在 if($this->addKey($tabName, $key)){ $this->mc->set($key, $data, MEMCACHE_COMPRESSED, 0); } } /** * 获取memcahce中保存的数据 * @param string $sql 使用SQL的key * @return mixed 返回缓存中的数据 */ function getCache($sql){ $key=md5($sql); return $this->mc->get($key); } /** * 删除和同一个表相关的所有缓存 * @param string $tabName 数据表的表名 */ function delCache($tabName){ $keys=$this->mc->get($tabName); //删除同一个表的所有缓存 if(!emptyempty($keys)){ foreach($keys as $key){ $this->mc->delete($key, 0); //0 表示立刻删除 } } //删除表的所有sql的key $this->mc->delete($tabName, 0); } /** * 删除单独一个语句的缓存 * @param string $sql 执行的SQL语句 */ function delone($sql){ $key=md5($sql); $this->mc->delete($key, 0); //0 表示立刻删除 } } ?>
看完上述内容,你们掌握如何在PHP中Memcached类实现内存缓存的方法了吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注亿速云行业资讯频道,感谢各位的阅读!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。