У меня есть этот класс базы данных, когда я использую тип базы данных как «MySQL«все работает нормально, но меняется от»MySQL«до»SQLite«выдает ошибку на странице.
Вот сообщение об ошибке
Fatal error: Uncaught exception 'Exception' with message 'SQLSTATE[HY000]: General error: 1 no such table: users' in E:\xampp\htdocs\projects\test\pdo\database.php:33 Stack trace: #0 E:\xampp\htdocs\projects\test\pdo\index.php(3): db->select('SELECT * FROM u...') #1 {main} thrown in E:\xampp\htdocs\projects\test\pdo\database.php on line 33
Это полный код класса.
class db{
public $isConnected;
protected $datab;
/* Database Object */
public function __construct($username, $password, $host, $dbname, $options=array()){
$this->isConnected = true;
try {
$this->datab = new PDO("mysql:host={$host};dbname={$dbname};charset=utf8", $username, $password, $options);
$this->datab->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
$this->datab->setAttribute(PDO::ATTR_DEFAULT_FETCH_MODE, PDO::FETCH_ASSOC);
}
catch(PDOException $e) {
$this->isConnected = false;
throw new Exception($e->getMessage());
}
}
/* Disconnect from the database */
public function disconnect(){
$this->datab = null;
$this->isConnected = false;
}
/* Select Query Against the Database */
public function select($query, $params=array()){
try{
$stmt = $this->datab->prepare($query);
$stmt->execute($params);
return $stmt->fetchAll();
}catch(PDOException $e){
throw new Exception($e->getMessage());
}
}
/* Insert Query Against the Database */
public function insert($query, $params){
try{
$stmt = $this->datab->prepare($query);
$stmt->execute($params);
}catch(PDOException $e){
throw new Exception($e->getMessage());
}
}
/* Update Query Against the Database */
public function update($query, $params){
return $this->insert($query, $params);
}
/* Delete Query Against the Database */
public function delete($query, $params){
return $this->insert($query, $params);
}
}
$db = new db("root", "", "localhost", "test", array(PDO::MYSQL_ATTR_INIT_COMMAND => 'SET NAMES utf8'));
Я смог решить эту проблему, комментируя расширения pdo sqlite на XAMPP.
Других решений пока нет …