问题:Class '\think\db\connector\Php-mysql' not found
分析:未查找到php-mysql驱动
//打开datebase.php文件,发现数据库类型不是MySQL
return [
// 数据库类型
'type' => 'php-mysql',
]
//修改为:
return [
// 数据库类型
'type' => 'mysql',
]
问题:could not find driver
//查看错误日志 Call Stack,发现php-mysql:host=127.0...'仍旧是php-mysql
in Connection.php line 293
at PDO->__construct('php-mysql:host=127.0...', 'root', 'root', [0, 2, 0, ...]) in Connection.php line 293
分析:因为tp使用的是pdo驱动
//思路一:是否开启pdo扩展,注:php_pdo_mysql.dll开启即可
extension=php_pdo_firebird.dll
extension=php_pdo_mysql.dll
结果:could not find driver
错误并不是扩展未开启导致的,那么问题出在哪里?
//思路二:Call Stack第二条提示中数据库驱动类型仍旧是php-mysql,查看mysql驱动文件
//发现Nysql.php文件中有如下代码:
protected function parseDsn($config)
{
if (!empty($config['socket'])) {
$dsn = 'php-mysql:unix_socket=' . $config['socket'];
} elseif (!empty($config['hostport'])) {
$dsn = 'php-mysql:host=' . $config['hostname'] . ';port=' . $config['hostport'];
} else {
$dsn = 'php-mysql:host=' . $config['hostname'];
}
$dsn .= ';dbname=' . $config['database'];
if (!empty($config['charset'])) {
$dsn .= ';charset=' . $config['charset'];
}
return $dsn;
}
//只需要将驱动名修改为mysql即可
//成功
200 OK Time:217 ms Size:1.56 KB JSON