CodeIgniter 3.1.10: невозможно подключиться к удаленной базе данных с помощью DSN с использованием ODBC - PullRequest
3 голосов
/ 20 марта 2019

У меня проблема с подключением к удаленной базе данных с помощью 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?

1 Ответ

0 голосов
/ 26 марта 2019

После долгих исследований по этому вопросу - я считаю, что проблема не в элементе ODBC, а в том, что вы не загружали библиотеку базы данных. Ошибка не относится к ODBC, но, как я обнаружил здесь: Codeigniter: драйвер базы данных в настоящее время не загружен из-за того, что я не считаю, что вы автоматически загрузили базу данных.

...