| <?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; |
| } |
| } |
|
|