程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> PHP綜合 >> PHP內存緩存Memcached類實例

PHP內存緩存Memcached類實例

編輯:PHP綜合

本文實例講述了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程序設計有所幫助。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved