Ошибка CodeIgniter при подключении к любой базе данных

1

Я только что загрузил новую копию CI со своего сайта (версия 3.0.3) и просто настроил базу данных и загрузил ее, но у меня возникла ошибка.

Ниже приведена конфигурация моей базы данных в config.php

$db['default'] = array(
'dsn'   => '',
'hostname' => 'localhost',
'username' => 'root',
'password' => '',
'database' => 'shortagesdb',
'dbdriver' => 'mysql',
'dbprefix' => '',
'pconnect' => FALSE,
'db_debug' => TRUE,//(ENVIRONMENT !== 'production'),
'cache_on' => FALSE,
'cachedir' => '',
'char_set' => 'utf8',
'dbcollat' => 'utf8_general_ci',
'swap_pre' => '',
'encrypt' => FALSE,
'compress' => FALSE,
'stricton' => FALSE,
'failover' => array(),
'save_queries' => TRUE

);

и вот что я делаю в своем контроллере, т.е. просто загружая базу данных

public function index()
{
    $this->load->database();
    $this->load->view('welcome_message');
}

Ничего особенного здесь, и я получаю это исключение, независимо от того, что

PHP Fatal error:  Call to undefined function mysql_connect() in D:\Projects\ims\system\database\drivers\mysql\mysql_driver.php on line 136

Любая помощь будет высоко оценен

  • 1
    замените 'dbdriver' => 'mysql' на 'dbdriver' => 'mysqli'
  • 0
    но я использую mysql или mssql, почему я должен использовать mysqli?
Показать ещё 5 комментариев
Теги:
database
codeigniter

2 ответа

3

Codeigniter 3 не поддерживает MySQL. MySQL устарел в версии 3.0

Попробуй это

$db['default'] = array(
'dsn'   => '',
'hostname' => 'localhost',
'username' => 'root', # check username
'password' => '', # check password
'database' => 'shortagesdb', # check DB name is correct
'dbdriver' => 'mysqli', # remove mysql
'dbprefix' => '',
'pconnect' => FALSE,
'db_debug' => (ENVIRONMENT !== 'production'), # remove 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

Изображение 174551

  • 0
    имя пользователя и пароль верны. Что делать, если я хочу использовать mssql сервер? я получаю ту же ошибку
  • 0
    Вы не можете использовать mysql в CI 3.
Показать ещё 5 комментариев
1

Проблема может быть в вашем файле php.ini, перейти в папку php и открыть этот файл в текстовом редакторе. Теперь найдите расширения и раскомментируйте это:

extension=php_mysqli.dll

Также проверьте, правильно ли указан путь расширения к папке ext в корневом каталоге php.

  • 0
    Если вы используете php7, убедитесь, что вы используете php.ini из php 7. /etc/php/7.0/cli

Ещё вопросы

Сообщество Overcoder
Наверх
Меню