PHP内存缓存Memcached类实例_php教程-查字典教程网
PHP内存缓存Memcached类实例
PHP内存缓存Memcached类实例
发布时间:2016-12-29 来源:查字典编辑
摘要:本文实例讲述了PHP内存缓存Memcached类。分享给大家供大家参考。具体实现方法如下:复制代码代码如下:1){foreach($para...

本文实例讲述了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程序设计有所帮助。

相关阅读
推荐文章
猜你喜欢
附近的人在看
推荐阅读
拓展阅读
  • 大家都在看
  • 小编推荐
  • 猜你喜欢
  • 最新php教程学习
    热门php教程学习
    编程开发子分类