我正在尝试在CodeIgniter应用程序中使用PDO MySQL驱动程序。这是我的数据库配置:
$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',消息'无效 数据源名称'in C:\ XAMPP \ htdocs中\测试网站\ SYSTEM \数据库\驱动\ PDO \ pdo_driver.php:114
我使用die($this->hostname);
中的pdo_driver.php
检查了数据来源,结果如下:
localhost;dbname=testdatabase
所以它获得了正确的数据库名称。数据库存在,我确实在运行MySQL。
这里可能出现什么问题?谢谢。
答案 0 :(得分:29)
在档案 /application/config/database.php 其中
$db['default']['hostname'] = 'localhost';
必须是
$db['default']['hostname'] = 'mysql:host=localhost';
localhost 或您的数据库主机。
答案 1 :(得分:10)
情况并非如此。
localhost;dbname=testdatabase
应该是
mysql:dbname=testdatabase;host=localhost;
答案 2 :(得分:7)
PDO驱动程序需要提供完整的DSN字符串。 像这样的字符串
'dsn' = ‘mysql:host=localhost;dbname=databasename’;
使用此字符串时,应从数组中删除host和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
);
由于
答案 3 :(得分:0)
根据CodeIgniter的Database Configuration页面,
对于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'),
.....
.....
);