2016-04-24 17 views
11

私は3.0.6へのステップバイ2.2.4ステップからの私のCodeIgniterのバージョンを更新したと私はエラーを取得:私はちょうど私のインデックスを交換したCodeIgniterのエラー:未定義の関数は、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 

を。 phpファイルとシステムディレクトリを新しいものに変更し、チュートリアルに従ってアプリケーションにいくつかの変更を加えました。

、これは主制御装置である:問題の原因は何

class Main extends CI_Controller { 

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

チュートリアルのthis is the link

+4

mysql_ *はphp5から廃止され、php7から削除されました。mysqli_ *またはPDO –

+0

への切り替えさらに、そのチュートリアルへのリンクを送信してください。 – SaidbakR

+0

問題はcodeigniterに付属していますか、私は自分のコードで廃止予定のmysqlを使用していますか? – Afshin

答えて

3

おかげAnant

私は結論に来るへ:から

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

は、私は完全に新しいものとconfigフォルダ内の私の古いdatabase.phpでファイルを変更

To:

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

エラーが消えました!

+0

あなたの 'dbdriver'設定値は空です。' $ db ['default'] ['dbdriver'] = 'mysqli'; ' – DotBot

+0

こんにちは、私はすでにあなたのソリューションを適用していますが、まだエラーが表示されます。他の解決策? – 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.

あなたが非推奨"mysql"dbdriverを使用していることが表示されます。 config/database.phpファイルを探し、mysqliを使用するようにdbdriverを変更:

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

あなたは、ウェブをホスト正しいPHPバージョン(1あなたのCIの使用)を設定してくださいときにこのエラーが起こった場合。

関連する問題