-
PHP内存缓存Memcached类实例
这篇文章主要介绍了PHP内存缓存Memcached类,以实例形式分析了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, '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);//www.phpfensi.com
- $this->mc->delete($key, 0); //0 表示立刻删除
- }
- }
- ?>
希望本文所述对大家的PHP程序设计有所帮助。
出处:http://www.phpfensi.com/php/20210503/14803.html
栏目列表
最新更新
nodejs爬虫
Python正则表达式完全指南
爬取豆瓣Top250图书数据
shp 地图文件批量添加字段
爬虫小试牛刀(爬取学校通知公告)
【python基础】函数-初识函数
【python基础】函数-返回值
HTTP请求:requests模块基础使用必知必会
Python初学者友好丨详解参数传递类型
如何有效管理爬虫流量?
SQL SERVER中递归
2个场景实例讲解GaussDB(DWS)基表统计信息估
常用的 SQL Server 关键字及其含义
动手分析SQL Server中的事务中使用的锁
openGauss内核分析:SQL by pass & 经典执行
一招教你如何高效批量导入与更新数据
天天写SQL,这些神奇的特性你知道吗?
openGauss内核分析:执行计划生成
[IM002]Navicat ODBC驱动器管理器 未发现数据
初入Sql Server 之 存储过程的简单使用
这是目前我见过最好的跨域解决方案!
减少回流与重绘
减少回流与重绘
如何使用KrpanoToolJS在浏览器切图
performance.now() 与 Date.now() 对比
一款纯 JS 实现的轻量化图片编辑器
关于开发 VS Code 插件遇到的 workbench.scm.
前端设计模式——观察者模式
前端设计模式——中介者模式
创建型-原型模式