У меня проблема с подключением к удаленной базе данных через DSN с использованием драйвера ODBC в CodeIgniter 3.1.10, как упоминалось выше. DSN был создан в Администраторе источника данных ODBC. Проблема возникла, когда я хочу обновить систему с CodeIgniter 2.2.3 до 3.1.10.
На самом деле он работает на CodeIgniter 2.2.3 с кодом ниже:
$db['default']['hostname'] = "myDSN";
$db['default']['username'] = '';
$db['default']['password'] = '';
$db['default']['database'] = 'myDatabase';
$db['default']['dbdriver'] = 'odbc';
$db['default']['dbprefix'] = '';
$db['default']['pconnect'] = FALSE;
$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;
Но он отображает ошибку ниже:
Драйвер базы данных в настоящее время не загружен
когда я пытался с теми же настройками на CodeIgniter 3.1.10, что и код ниже:
$db['default'] = array(
'dsn' => '',
'hostname' => 'myDSN',
'username' => '',
'password' => '',
'database' => 'myDatabase',
'dbdriver' => 'odbc',
'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 3.1.10 подключение выполняется успешно, когда я вручную подключаюсь к базе данных, используя приведенный ниже код:
$dbconn=odbc_connect("myDSN", "", "");
if(!$dbconn)
{
die("Could not connect Adaptive Server Anywhere: ".odbc_errormsg(). odbc_error());
} else {
echo "connection success";
}
Итак, поскольку он может подключаться при использовании ручного кода, может ли кто-нибудь помочь мне успешно подключиться с помощью кода базы данных в CodeIgniter 3.1.10?