您好,登錄后才能下訂單哦!
如何在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進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。