本文实例讲述了PHP内存缓存Memcached类。分享给大家供大家参考。
具体实现方法如下:
代码如下:
1){
foreach ($params as $v){
call_user_func_array(array($mc,'addServer'),$v);
}
//如果只有一个memcache服务器
} else {
call_user_func_array(array($mc,$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,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程序设计有所帮助。