>백엔드 개발 >PHP 튜토리얼 >PHP memcached 캐시 클래스 코드 예

PHP memcached 캐시 클래스 코드 예

WBOY
WBOY원래의
2016-07-25 08:52:15818검색
  1. class MemcacheModel {
  2. private $mc = null;
  3. /**
  4. * 构造方法,用于添加服务器并创建memcahced对象
  5. */
  6. function __construct(){
  7. $params = func_get_args();
  8. $mc = new Memcache;
  9. //如果有多个memcache服务器
  10. if( count($params) > 1){
  11. foreach ($params as $v){
  12. call_user_func_array(array($mc, 'addServer'), $v);
  13. }
  14. //如果只有一个memcache服务器
  15. } else {
  16. call_user_func_array(array($mc, 'addServer'), $params[0]);
  17. }
  18. $this->mc=$mc;
  19. }
  20. /**
  21. * 获取memcached对象
  22. * @return object memcached对象
  23. */
  24. function getMem(){
  25. return $this->mc;
  26. }
  27. /**
  28. * 检查mem是否连接成功
  29. * @return bool 连接成功返回true,否则返回false
  30. */
  31. function mem_connect_error(){
  32. $stats=$this->mc->getStats();
  33. if(emptyempty($stats)){
  34. return false;
  35. }else{
  36. return true;
  37. }
  38. }
  39. private function addKey($tabName, $key){
  40. $keys=$this->mc->get($tabName);
  41. if(emptyempty($keys)){
  42. $keys=array();
  43. }
  44. //如果key不存在,就添加一个
  45. if(!in_array($key, $keys)) {
  46. $keys[]=$key; //将新的key添加到本表的keys中
  47. $this->mc->set($tabName, $keys, MEMCACHE_COMPRESSED, 0);
  48. return true; //不存在返回true
  49. }else{
  50. return false; //存在返回false
  51. }
  52. }
  53. /**
  54. * 向memcache中添加数据
  55. * @param string $tabName 需要缓存数据表的表名
  56. * @param string $sql 使用sql作为memcache的key
  57. * @param mixed $data 需要缓存的数据
  58. */
  59. function addCache($tabName, $sql, $data){
  60. $key=md5($sql);
  61. //如果不存在
  62. if($this->addKey($tabName, $key)){
  63. $this->mc->set($key, $data, MEMCACHE_COMPRESSED, 0);
  64. }
  65. }
  66. /**
  67. * 获取memcahce中保存的数据
  68. * @param string $sql 使用SQL的key
  69. * @return mixed 返回缓存中的数据
  70. */
  71. function getCache($sql){
  72. $key=md5($sql);
  73. return $this->mc->get($key);
  74. }
  75. /**
  76. * 删除和同一个表相关的所有缓存
  77. * @param string $tabName 数据表的表名
  78. */
  79. function delCache($tabName){
  80. $keys=$this->mc->get($tabName);
  81. //删除同一个表的所有缓存
  82. if(!emptyempty($keys)){
  83. foreach($keys as $key){
  84. $this->mc->delete($key, 0); //0 表示立刻删除
  85. }
  86. }
  87. //删除表的所有sql的key
  88. $this->mc->delete($tabName, 0);
  89. }
  90. /**
  91. * 删除单独一个语句的缓存
  92. * @param string $sql 执行的SQL语句
  93. */
  94. function delone($sql){
  95. $key=md5($sql);
  96. $this->mc->delete($key, 0); //0 表示立刻删除
  97. }
  98. }
  99. ?>
复制代码


성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.