| | <?php |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| |
|
| | namespace think\cache\driver; |
| |
|
| | use think\cache\Driver; |
| |
|
| | |
| | |
| | |
| | |
| | class Sqlite extends Driver |
| | { |
| | protected $options = [ |
| | 'db' => ':memory:', |
| | 'table' => 'sharedmemory', |
| | 'prefix' => '', |
| | 'expire' => 0, |
| | 'persistent' => false, |
| | ]; |
| |
|
| | |
| | |
| | |
| | |
| | |
| | |
| | public function __construct($options = []) |
| | { |
| | if (!extension_loaded('sqlite')) { |
| | throw new \BadFunctionCallException('not support: sqlite'); |
| | } |
| | if (!empty($options)) { |
| | $this->options = array_merge($this->options, $options); |
| | } |
| | $func = $this->options['persistent'] ? 'sqlite_popen' : 'sqlite_open'; |
| | $this->handler = $func($this->options['db']); |
| | } |
| |
|
| | |
| | |
| | |
| | |
| | |
| | |
| | protected function getCacheKey($name) |
| | { |
| | return $this->options['prefix'] . sqlite_escape_string($name); |
| | } |
| |
|
| | |
| | |
| | |
| | |
| | |
| | |
| | public function has($name) |
| | { |
| | $name = $this->getCacheKey($name); |
| | $sql = 'SELECT value FROM ' . $this->options['table'] . ' WHERE var=\'' . $name . '\' AND (expire=0 OR expire >' . $_SERVER['REQUEST_TIME'] . ') LIMIT 1'; |
| | $result = sqlite_query($this->handler, $sql); |
| | return sqlite_num_rows($result); |
| | } |
| |
|
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | public function get($name, $default = false) |
| | { |
| | $name = $this->getCacheKey($name); |
| | $sql = 'SELECT value FROM ' . $this->options['table'] . ' WHERE var=\'' . $name . '\' AND (expire=0 OR expire >' . $_SERVER['REQUEST_TIME'] . ') LIMIT 1'; |
| | $result = sqlite_query($this->handler, $sql); |
| | if (sqlite_num_rows($result)) { |
| | $content = sqlite_fetch_single($result); |
| | if (function_exists('gzcompress')) { |
| | |
| | $content = gzuncompress($content); |
| | } |
| | return unserialize($content); |
| | } |
| | return $default; |
| | } |
| |
|
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | public function set($name, $value, $expire = null) |
| | { |
| | $name = $this->getCacheKey($name); |
| | $value = sqlite_escape_string(serialize($value)); |
| | if (is_null($expire)) { |
| | $expire = $this->options['expire']; |
| | } |
| | if ($expire instanceof \DateTime) { |
| | $expire = $expire->getTimestamp(); |
| | } else { |
| | $expire = (0 == $expire) ? 0 : (time() + $expire); |
| | } |
| | if (function_exists('gzcompress')) { |
| | |
| | $value = gzcompress($value, 3); |
| | } |
| | if ($this->tag) { |
| | $tag = $this->tag; |
| | $this->tag = null; |
| | } else { |
| | $tag = ''; |
| | } |
| | $sql = 'REPLACE INTO ' . $this->options['table'] . ' (var, value, expire, tag) VALUES (\'' . $name . '\', \'' . $value . '\', \'' . $expire . '\', \'' . $tag . '\')'; |
| | if (sqlite_query($this->handler, $sql)) { |
| | return true; |
| | } |
| | return false; |
| | } |
| |
|
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | public function inc($name, $step = 1) |
| | { |
| | if ($this->has($name)) { |
| | $value = $this->get($name) + $step; |
| | } else { |
| | $value = $step; |
| | } |
| | return $this->set($name, $value, 0) ? $value : false; |
| | } |
| |
|
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | public function dec($name, $step = 1) |
| | { |
| | if ($this->has($name)) { |
| | $value = $this->get($name) - $step; |
| | } else { |
| | $value = -$step; |
| | } |
| | return $this->set($name, $value, 0) ? $value : false; |
| | } |
| |
|
| | |
| | |
| | |
| | |
| | |
| | |
| | public function rm($name) |
| | { |
| | $name = $this->getCacheKey($name); |
| | $sql = 'DELETE FROM ' . $this->options['table'] . ' WHERE var=\'' . $name . '\''; |
| | sqlite_query($this->handler, $sql); |
| | return true; |
| | } |
| |
|
| | |
| | |
| | |
| | |
| | |
| | |
| | public function clear($tag = null) |
| | { |
| | if ($tag) { |
| | $name = sqlite_escape_string($tag); |
| | $sql = 'DELETE FROM ' . $this->options['table'] . ' WHERE tag=\'' . $name . '\''; |
| | sqlite_query($this->handler, $sql); |
| | return true; |
| | } |
| | $sql = 'DELETE FROM ' . $this->options['table']; |
| | sqlite_query($this->handler, $sql); |
| | return true; |
| | } |
| | } |
| |
|