2016-04-24 13 views
11

Ich habe meine codeigniter Version von 2.2.4 Schritt für Schritt 3.0.6 aktualisiert und ich erhalte eine Fehlermeldung:Codeigniter error: Call to undefined function mysql_pconnect()

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 

Ich habe gerade meinen Index ersetzt. PHP-Datei und System-Verzeichnis mit dem neuen und machte einige Änderungen in meiner Anwendung nach Tutorial.

und das ist der Hauptregler:

class Main extends CI_Controller { 

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

Was das Problem verursacht ?!

Und this is the link des Tutorials.

+4

mysql_ * ist von PHP 5 veraltet und von PHP 7 entfernt. Wechseln Sie zu mysqli_ * oder PDO –

+0

. Senden Sie außerdem einen Link zu diesem Lernprogramm. – SaidbakR

+0

Jetzt kommt das Problem mit dem Codeigniter oder ich verwende die veraltete mysql in meinem Code? – Afshin

Antwort

3

Dank Anant

ich zum Schluss gekommen:

Von:

ich meine alten database.php Datei in config-Ordner mit den neuen komplett verändert

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

An:

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

Und der Fehler ist weg!

+0

Ihr 'dbdriver' config Wert ist leer, Sie sollten' $ db ['default'] ['dbdriver'] = 'mysqli'; ' – DotBot

+0

verwenden Hi, ich habe bereits Ihre Lösung angewendet, aber der Fehler tritt immer noch auf. irgendeine andere Lösung? – Jjsg08

33

Deprecated features in PHP 5.5.x:

The original MySQL extension is now deprecated, and will generate E_DEPRECATED errors when connecting to a database. Instead, use the MySQLi or PDO_MySQL extensions.

Es scheint, dass Sie die veraltete "mysql"dbdriver verwenden. Suchen Sie die config/database.php Datei und ändern dbdrivermysqli zu verwenden:

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

Wenn dieser Fehler passiert, wenn Sie die Web-Host, stellen Sie sicher, die richtige PHP Version (die CI-Nutzung) zu setzen.

Verwandte Themen