未定义的函数mssql_connect()Codeigniter 3.0 + Azure数据库+ 000webhost + PHP 5.6

时间:2018-06-19 11:27:43

标签: php sql codeigniter azure-sql-database codeigniter-3

我在000webhost(PHP 5.6)上使用Codeigniter 3.0,并尝试连接到Microsoft Azure上的数据库。

我的database.php文件具有以下配置:

$db['default'] = array(
    'dsn'   => '',
    'hostname' => 'xxxx.database.windows.net',
    'port' => '1433',
    'username' => 'abcd',
    'password' => '*****',
    'database' => 'mydb',
    'dbdriver' => 'mssql',
    '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
);

我收到以下错误: enter image description here

我尝试将dbdriver更改为sqlsrv。但是,除了现在它抱怨sqlsrv_connect()未定义之外,我得到了相同的错误。

PHP信息如下: PHP INFO OUTPUT

2 个答案:

答案 0 :(得分:0)

尝试一下, 在application \ config \ database.php中的设置应类似于:

'hostname' => '<server_name>.database.windows.net,1433',
'username' => '<username>',
'password' => '<password>',
'database' => '<database>',
'dbdriver' => 'sqlsrv',
'pconnect' => FALSE,

Azure不会自动安装php_mssql.dll,但会安装php_sqlsrv.dll 所以上面的。

答案 1 :(得分:0)

根据您安装的phpinfo mysqli尝试此操作

'dbdriver' => 'mysqli',