| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138 | 
							- <?php
 
- // +----------------------------------------------------------------------
 
- // | ThinkPHP [ WE CAN DO IT JUST THINK IT ]
 
- // +----------------------------------------------------------------------
 
- // | Copyright (c) 2006-2014 http://thinkphp.cn All rights reserved.
 
- // +----------------------------------------------------------------------
 
- // | Licensed ( http://www.apache.org/licenses/LICENSE-2.0 )
 
- // +----------------------------------------------------------------------
 
- // | Author: liu21st <liu21st@gmail.com>
 
- // +----------------------------------------------------------------------
 
- namespace Think\Cache\Driver;
 
- use Think\Cache;
 
- defined('THINK_PATH') or exit();
 
- /**
 
-  * 数据库方式缓存驱动
 
-  *    CREATE TABLE think_cache (
 
-  *      cachekey varchar(255) NOT NULL,
 
-  *      expire int(11) NOT NULL,
 
-  *      data blob,
 
-  *      datacrc int(32),
 
-  *      UNIQUE KEY `cachekey` (`cachekey`)
 
-  *    );
 
-  */
 
- class Db extends Cache {
 
-     /**
 
-      * 架构函数
 
-      * @param array $options 缓存参数
 
-      * @access public
 
-      */
 
-     public function __construct($options=array()) {
 
-         if(empty($options)) {
 
-             $options = array (
 
-                 'table'     =>  C('DATA_CACHE_TABLE'),
 
-             );
 
-         }
 
-         $this->options  =   $options;   
 
-         $this->options['prefix']    =   isset($options['prefix'])?  $options['prefix']  :   C('DATA_CACHE_PREFIX');
 
-         $this->options['length']    =   isset($options['length'])?  $options['length']  :   0;        
 
-         $this->options['expire']    =   isset($options['expire'])?  $options['expire']  :   C('DATA_CACHE_TIME');
 
-         $this->handler   = \Think\Db::getInstance();
 
-     }
 
-     /**
 
-      * 读取缓存
 
-      * @access public
 
-      * @param string $name 缓存变量名
 
-      * @return mixed
 
-      */
 
-     public function get($name) {
 
-         $name       =  $this->options['prefix'].addslashes($name);
 
-         N('cache_read',1);
 
-         $result     =  $this->handler->query('SELECT `data`,`datacrc` FROM `'.$this->options['table'].'` WHERE `cachekey`=\''.$name.'\' AND (`expire` =0 OR `expire`>'.time().') LIMIT 0,1');
 
-         if(false !== $result ) {
 
-             $result   =  $result[0];
 
-             if(C('DATA_CACHE_CHECK')) {//开启数据校验
 
-                 if($result['datacrc'] != md5($result['data'])) {//校验错误
 
-                     return false;
 
-                 }
 
-             }
 
-             $content   =  $result['data'];
 
-             if(C('DATA_CACHE_COMPRESS') && function_exists('gzcompress')) {
 
-                 //启用数据压缩
 
-                 $content   =   gzuncompress($content);
 
-             }
 
-             $content    =   unserialize($content);
 
-             return $content;
 
-         }
 
-         else {
 
-             return false;
 
-         }
 
-     }
 
-     /**
 
-      * 写入缓存
 
-      * @access public
 
-      * @param string $name 缓存变量名
 
-      * @param mixed $value  存储数据
 
-      * @param integer $expire  有效时间(秒)
 
-      * @return boolean
 
-      */
 
-     public function set($name, $value,$expire=null) {
 
-         $data   =  serialize($value);
 
-         $name   =  $this->options['prefix'].addslashes($name);
 
-         N('cache_write',1);
 
-         if( C('DATA_CACHE_COMPRESS') && function_exists('gzcompress')) {
 
-             //数据压缩
 
-             $data   =   gzcompress($data,3);
 
-         }
 
-         if(C('DATA_CACHE_CHECK')) {//开启数据校验
 
-             $crc  =  md5($data);
 
-         }else {
 
-             $crc  =  '';
 
-         }
 
-         if(is_null($expire)) {
 
-             $expire  =  $this->options['expire'];
 
-         }
 
-         $expire	    =   ($expire==0)?0: (time()+$expire) ;//缓存有效期为0表示永久缓存
 
-         $result     =   $this->handler->query('select `cachekey` from `'.$this->options['table'].'` where `cachekey`=\''.$name.'\' limit 0,1');
 
-         if(!empty($result) ) {
 
-         	//更新记录
 
-             $result  =  $this->handler->execute('UPDATE '.$this->options['table'].' SET data=\''.$data.'\' ,datacrc=\''.$crc.'\',expire='.$expire.' WHERE `cachekey`=\''.$name.'\'');
 
-         }else {
 
-         	//新增记录
 
-              $result  =  $this->handler->execute('INSERT INTO '.$this->options['table'].' (`cachekey`,`data`,`datacrc`,`expire`) VALUES (\''.$name.'\',\''.$data.'\',\''.$crc.'\','.$expire.')');
 
-         }
 
-         if($result) {
 
-             if($this->options['length']>0) {
 
-                 // 记录缓存队列
 
-                 $this->queue($name);
 
-             }
 
-             return true;
 
-         }else {
 
-             return false;
 
-         }
 
-     }
 
-     /**
 
-      * 删除缓存
 
-      * @access public
 
-      * @param string $name 缓存变量名
 
-      * @return boolean
 
-      */
 
-     public function rm($name) {
 
-         $name  =  $this->options['prefix'].addslashes($name);
 
-         return $this->handler->execute('DELETE FROM `'.$this->options['table'].'` WHERE `cachekey`=\''.$name.'\'');
 
-     }
 
-     /**
 
-      * 清除缓存
 
-      * @access public
 
-      * @return boolean
 
-      */
 
-     public function clear() {
 
-         return $this->handler->execute('TRUNCATE TABLE `'.$this->options['table'].'`');
 
-     }
 
- }
 
 
  |