无法使用提供的设置连接到数据库服务器。在CodeIgniter上

时间:2018-02-12 03:21:07

标签: php mysql database codeigniter

我只是转移我的域名并将我的托管服务器迁移到订购服务托管,但转移域仍处于待处理状态。我为我的cpanel和我的网站提供了一个新的用户名和密码,显示如下错误:

    A Database Error Occurred

    Unable to connect to your database server using the provided settings.

    Filename: core/Loader.php

    Line Number: 346

我在这个网站上使用CodeIgniter 3和MySQL,我认为database.php文件中的config目录中存在问题。我更改了password中的旧用户名usernamedatabase.php。但结果仍然没有改变。

这是我的database.php:

$db['default']['hostname'] = '(*My IP Domain)';
$db['default']['username'] = '(*My Username Cpanel)';
$db['default']['password'] = '(*My Password Cpanel)';
$db['default']['database'] = '(*My Database name)';
$db['default']['dbdriver'] = 'mysql';
$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;

我不知道如何修复它,错误是否可能在另一个文件中?

3 个答案:

答案 0 :(得分:0)

如果您使用共享托管,则必须使用您的域前缀定义数据库名称。

例如:如果我的网站为stackoverflow,那么我可以创建stackoverflow_tabalename

因此,您的表名称为stackoverflow_tabalename,DB User也应该采用相同的方法(stackoverflow_userName

并使用MySQLi,Cz 3.0停止支持MySQL

$db['default']['hostname'] = 'localhost';
$db['default']['username'] = 'stackoverflow_tabalename';
$db['default']['password'] = 'stackoverflow_userName';
$db['default']['database'] = 'passwordGoesHere';
$db['default']['dbdriver'] = 'mysqli';
  

注意:使用MySQL® Database Wizard创建数据库,用户和密码。

答案 1 :(得分:0)

$active_group = 'default';

$query_builder = TRUE;

$db['default'] = array(

'dsn'   => '',
'hostname' => 'localhost',
'username' => 'your-user-name',
'password' => 'your-password',
'database' => 'DB-name',
'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 :(得分:0)

在database.php上 将mysql更改为mysqli

如果仍然错误

更改与本地使用相同的php版本