配置:
1 2
| 'DB_TYPE' => 'sqlite', 'DB_NAME' => DATA_PATH.'/test.db',
|
文件:\Library\Think\Db\Driver\Sqlite.class.php
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104
| namespace Think\Db\Driver;
use Think\Db\Driver;
class Sqlite extends Driver {
protected function parseDsn($config) { $dsn = 'sqlite:' . $config['database']; return $dsn; }
public function getFields($tableName) { list($tableName) = explode(' ', $tableName); $result = $this->query('PRAGMA table_info( ' . $tableName . ' )'); $info = array(); if ($result) { foreach ($result as $key => $val) { $info[$val['name']] = array( 'name' => $val['name'], 'type' => $val['type'], 'notnull' => (bool) (1 === $val['notnull']), 'default' => $val['dflt_value'], 'primary' => '1' == $val['pk'], 'autoinc' => false, ); } } return $info; }
public function getTables($dbName = '') { $result = $this->query("SELECT name FROM sqlite_master WHERE type='table' " . "UNION ALL SELECT name FROM sqlite_temp_master " . "WHERE type='table' ORDER BY name"); $info = array(); foreach ($result as $key => $val) { $info[$key] = current($val); } return $info; }
public function escapeString($str) { return str_ireplace("'", "''", $str); }
public function parseLimit($limit) { $limitStr = ''; if (!empty($limit)) { $limit = explode(',', $limit); if (count($limit) > 1) { $limitStr .= ' LIMIT ' . $limit[1] . ' OFFSET ' . $limit[0] . ' '; } else { $limitStr .= ' LIMIT ' . $limit[0] . ' '; } } return $limitStr; }
protected function parseRand() { return 'RANDOM()'; } }
|