CodeIgniter PDO数据库驱动程序不起作用


CodeIgniter PDO database driver not working

我正在尝试在我的CodeIgniter应用程序中使用PDOMySQL驱动程序。这是我的数据库配置:

$active_group = 'default';
$active_record = TRUE;
$db['default']['hostname'] = 'localhost';
$db['default']['username'] = 'root';
$db['default']['password'] = '';
$db['default']['database'] = 'testdatabase';
$db['default']['dbdriver'] = 'pdo';
$db['default']['dbprefix'] = '';
$db['default']['pconnect'] = TRUE;
$db['default']['db_debug'] = TRUE;
$db['default']['cache_on'] = FALSE;
$db['default']['cachedir'] = '';
$db['default']['char_set'] = 'utf8';
$db['default']['dbcollat'] = 'utf8_general_ci';
$db['default']['swap_pre'] = '';
$db['default']['autoinit'] = TRUE;
$db['default']['stricton'] = FALSE;

但是,当我加载控制器时,我收到此错误:

致命错误:未捕获的异常"PDOException",消息"无效" 数据源名称"中的 C:''xampp''htdocs''testsite''system''database''drivers''pdo''pdo_driver.php:114

我已经在pdo_driver.php中使用die($this->hostname);检查了数据源,结果为:

localhost;dbname=testdatabase

因此,它正在获取正确的数据库名称。数据库存在,我确实正在运行MySQL。

这里可能出了什么问题?谢谢。

在文件/application/config/database 上.php 在哪里

$db['default']['hostname'] = 'localhost';

必须是

$db['default']['hostname'] = 'mysql:host=localhost';

本地主机或您的数据库主机。

不应该是这种情况。

localhost;dbname=testdatabase

应该是

mysql:dbname=testdatabase;host=localhost;

PDO 驱动程序需要提供完整的 DSN 字符串。像这样的字符串

'dsn' = ‘mysql:host=localhost;dbname=databasename’;

使用此字符串时,应从数组中删除主机和数据库名称值。我认为以下示例可以为您提供一个想法。

$db['default'] = array(
'dsn'   => 'mysql:host=localhost;dbname=codeigniter3',
'hostname' => '',
'username' => 'root',
'password' => '',
'database' => '',
'dbdriver' => 'pdo',
'dbprefix' => '',
'pconnect' => FALSE,
'db_debug' => TRUE,
'cache_on' => FALSE,
'cachedir' => '',
'char_set' => 'utf8',
'dbcollat' => 'utf8_general_ci',
'swap_pre' => '',
'encrypt' => FALSE,
'compress' => FALSE,
'stricton' => FALSE,
'failover' => array(),
'save_queries' => TRUE
);

谢谢

根据CodeIgniter的数据库配置页面,

对于PDO驱动程序,您应该将"hostname => 'localhost'"更改为"'hostname' => mysql:host=localhost",如下所示:

$db['default'] = array(
    'dsn'   => '',
    'hostname' => 'mysql:host=localhost',
    'username' => 'root',
    'password' => '',
    'database' => 'database_name',
    'dbdriver' => 'pdo',
    'dbprefix' => '',
    'pconnect' => FALSE,
    'db_debug' => (ENVIRONMENT !== 'production'),
     .....
     .....
);