Php 将CI与SQL Server 2008 R2连接

Php 将CI与SQL Server 2008 R2连接,php,mysql,sql,sql-server,codeigniter,Php,Mysql,Sql,Sql Server,Codeigniter,我知道这个问题已经问了100次了 但我在这里真的很绝望 我使用Windows7 通常,我使用CodeIgniter将PHP和MYSQL编码为我的数据库 我用 xampp 1.8.1 [PHP:5.4.7] 在application\config\database.php中,我使用 $db['default']['hostname'] = 'localhost'; $db['default']['username'] = ''; $db['default']['password'] = ''; $

我知道这个问题已经问了100次了

但我在这里真的很绝望

我使用Windows7

通常,我使用CodeIgniter将PHP和MYSQL编码为我的数据库

我用 xampp 1.8.1 [PHP:5.4.7]

在application\config\database.php中,我使用

$db['default']['hostname'] = 'localhost';
$db['default']['username'] = '';
$db['default']['password'] = '';
$db['default']['database'] = 'test';
$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;
在我的system\database\DB\u driver.php中,我使用

    var $dbdriver       = 'mysql';
    var $dbprefix       = '';
    var $char_set       = 'utf8';
    var $dbcollat       = 'utf8_general_ci';
    var $autoinit       = TRUE; // Whether to automatically initialize the DB
    var $swap_pre       = '';
    var $port           = '';
    var $pconnect       = FALSE;
    var $conn_id        = FALSE;
    var $result_id      = FALSE;
    var $db_debug       = FALSE;
    var $benchmark      = 0;
    var $query_count    = 0;
    var $bind_marker    = '?';
    var $save_queries   = TRUE;
    var $queries        = array();
    var $query_times    = array();
    var $data_cache     = array();
    var $trans_enabled  = TRUE;
    var $trans_strict   = TRUE;
    var $_trans_depth   = 0;
    var $_trans_status  = TRUE; // Used with transactions to determine if a rollback should occur
    var $cache_on       = FALSE;
    var $cachedir       = '';
    var $cache_autodel  = FALSE;
    var $CACHE; // The cache class object
在我的控制器中,我使用

$query = $this->db->query('SELECT * FROM asal');
foreach ($query->result_array() as $row)
        {
            echo $row['asalid'];
        }
它工作得很好

但这是使用php的mysql

现在,我需要将我的PHP与microsfot SQL Server 2008 R2连接起来

这就是我所经历的

首先,我从这里安装sqlsrv驱动程序SQLSRV30.exe

它说PHP5应该使用SQLSRV30

接下来,我将其解压缩到我的php/ext中

现在在我的php/ext中,我已经从SQLSRV30.exe中提取了8个额外的文件,如下所示

php_sqlsrv_54_ts.dll
php_sqlsrv_53_ts.dll
php_sqlsrv_54_nts.dll
php_sqlsrv_53_nts.dll

php_pdo_sqlsrv_54_ts.dll
php_pdo_sqlsrv_53_ts.dll
php_pdo_sqlsrv_54_nts.dll
php_pdo_sqlsrv_53_nts.dll
那么, 我也尝试添加这些句子

extension=php_sqlsrv_54_nts.dll
extension=php_pdo_sqlsrv_54_nts.dll
在我的php.ini中

最后,

我将application\config\database.php更改为

    $db['default']['hostname'] = 'NB-EDP-04\SQLEXPRESS';
    $db['default']['username'] = '';
    $db['default']['password'] = '';
    $db['default']['database'] = 'test';
    $db['default']['dbdriver'] = 'mysql';
    $db['default']['dbprefix'] = '';
    $db['default']['pconnect'] = FALSE;
    $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;
另外,我的system\database\DB\u driver.php

    var $dbdriver       = 'sqlsrv';
    var $dbprefix       = '';
    var $char_set       = 'utf8';
    var $dbcollat       = 'utf8_general_ci';
    var $autoinit       = TRUE; // Whether to automatically initialize the DB
    var $swap_pre       = '';
    var $port           = '';
    var $pconnect       = FALSE;
    var $conn_id        = FALSE;
    var $result_id      = FALSE;
    var $db_debug       = FALSE;
    var $benchmark      = 0;
    var $query_count    = 0;
    var $bind_marker    = '?';
    var $save_queries   = TRUE;
    var $queries        = array();
    var $query_times    = array();
    var $data_cache     = array();
    var $trans_enabled  = TRUE;
    var $trans_strict   = TRUE;
    var $_trans_depth   = 0;
    var $_trans_status  = TRUE; // Used with transactions to determine if a rollback should occur
    var $cache_on       = FALSE;
    var $cachedir       = '';
    var $cache_autodel  = FALSE;
    var $CACHE; // The cache class object
但不好,在我的URL中键入localhost/edp之后,我一直收到这个错误

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

Filename: C:\xampp\htdocs\edp\system\database\DB_driver.php

Line Number: 127
我使用MicrosoftC应用程序进行测试

我试着连接到同一个数据库,它工作正常

我可以选择数据库中的表

所以我想,我的数据库的远程连接已经激活了

请帮我谢谢

好的,问题解决了

我的问题是本地客户

我进入控制面板>程序和功能

我搜索Microsoft SQL Server 2008 R2本机客户端的

因为我使用的是microsoft SQL Server 2008 R2

它会说,不建议卸载本机客户端,但只要我们安装其他本机客户端就可以了

我下载

Microsoft SQL Server 2012本机客户端

而且,它解决了,我不知道会发生什么,我只知道,它帮助我的php应用程序连接到ms sql server 2008 R2