搜尋
首頁php教程php手册如何用PHP内存缓存Memcached类(附代码)

如何用PHP内存缓存Memcached类(附代码)

Jun 06, 2016 pm 08:17 PM
memcachedphp快取

这篇文章主要介绍了PHP内存缓存Memcached类,以实例形式分析了PHP内存缓存Memcached的实现方法,是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, &#39;addServer&#39;), $v); 
} 
//如果只有一个memcache服务器 
} else { 
call_user_func_array(array($mc, &#39;addServer&#39;), $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 表示立刻删除 
} 
} 
?>

【相关教程推荐】

1. php编程从入门到精通全套视频教程
2. php从入门到精通 
3. bootstrap教程

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

MantisBT

MantisBT

Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。

EditPlus 中文破解版

EditPlus 中文破解版

體積小,語法高亮,不支援程式碼提示功能

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強大的PHP整合開發環境

Safe Exam Browser

Safe Exam Browser

Safe Exam Browser是一個安全的瀏覽器環境,安全地進行線上考試。該軟體將任何電腦變成一個安全的工作站。它控制對任何實用工具的訪問,並防止學生使用未經授權的資源。

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)