12

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;

ただし、コントローラーをロードすると、次のエラーが発生します。

致命的なエラー: C:\xampp\htdocs\testsite\system\database\drivers\pdo\pdo_driver.php:114 でメッセージ「無効なデータ ソース名」を含む例外「PDOException」がキャッチされない

die($this->hostname);inを使用してデータ ソースを確認しましたが、pdo_driver.php次のように表示されます。

localhost;dbname=testdatabase

そのため、正しいデータベース名を取得しています。データベースが存在し、MySQL を実行しています。

ここで何がうまくいかないのでしょうか?ありがとうございました。

4

4 に答える 4

29

ファイル/application/config/database.phpの場所

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

でなければなりません

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

localhostまたはデータベース ホスト。

于 2012-11-27T15:57:57.220 に答える
11

これは当てはまりません。

localhost;dbname=testdatabase

する必要があります

mysql:dbname=testdatabase;host=localhost;
于 2012-06-15T16:23:59.770 に答える
7

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
);

ありがとう

于 2015-08-26T08:12:57.893 に答える
0

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'),
     .....
     .....
);
于 2015-07-31T07:05:16.257 に答える