Ошибка Codeigniter: вызов неопределенной функции mysql_pconnect()

Я обновил мою версию codeigniter от 2.2.4 шаг за шагом до 3.0.6, и я получаю сообщение об ошибке:

An uncaught Exception was encountered

Type: Error

Message: Call to undefined function mysql_pconnect()

Filename: path-to-project\system\database\drivers\mysql\mysql_driver.php

Line Number: 135

Backtrace:

File: path-to-project\application\controllers\Main.php
Line: 10
Function: __construct

File: path-to-project\index.php
Line: 315
Function: require_once

Я только что заменил свой файл index.php и системный каталог на новый и внес некоторые изменения в свое приложение в соответствии с учебником.

и это главный контроллер:

class Main extends CI_Controller {

    function __construct()
    {
        parent::__construct();
        $this->load->model('main_model');
    }
}

Что вызывает проблему?!

И это ссылка учебника.

Ответы

Ответ 1

Благодаря Anant

Я пришел к выводу:

Я полностью изменил свой старый файл database.php в папке config с новым:

Из:

$db['default']['hostname'] = 'localhost';
$db['default']['username'] = '';
$db['default']['password'] = '';
$db['default']['database'] = '';
$db['default']['dbdriver'] = '';
$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;

Для того, чтобы:

$db['default'] = array(
    'dsn'   => '',
    'hostname' => '',
    'username' => '',
    'password' => '',
    'database' => '',
    'dbdriver' => 'mysqli',
    'dbprefix' => '',
    'pconnect' => FALSE,
    'db_debug' => (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
);

И ошибка исчезла!

Ответ 2

Устаревшие функции в PHP 5.5.x:

Исходное расширение MySQL теперь устарело и будет генерировать ошибки E_DEPRECATED при подключении к базе данных. Вместо этого используйте расширения MySQLi или PDO_MySQL.

Вы используете устаревший 'mysql' dbdriver. Найдите файл config/database.php и измените dbdriver на использование 'mysqli':

$db['default']['dbdriver'] = 'mysqli'; 

Ответ 3

изменить "mysql" на "mysqli" в файле database.php

$db['default']['dbdriver'] = 'mysqli';

Ответ 4

Просто внесите изменения в файл database.php

$db['default']['dbdriver'] = 'mysql';

в

$db['default']['dbdriver'] = 'mysqli';

Ответ 5

Если эта ошибка произошла, когда вы размещаете веб-сайт, обязательно установите правильную версию PHP (тот, который использует ваш CI).