我知道这个问题已经问了100次
但我真的绝望了
我使用的是Windows 7
通常,我使用Code Igniter将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_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) http://www.microsoft.com/en-us/download/details.aspx?id=20098
(它说php 5应该使用SQLSRV30)
接下来,我将它解压缩到我的php / ext
现在在我的php / ext中我已经有8个从SQLSRV30.exe中提取的附加文件
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;
我的系统\ database \ DB_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
但不好,我在我的网址
输入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
我使用microsoft c#application测试
我尝试连接到同一个数据库,它可以正常工作
我可以选择该数据库中的表格
所以我认为,我的数据库的远程连接已经激活
请帮助我谢谢
答案 0 :(得分:0)
好吧,它解决了
我的问题是本机客户端
我去控制面板>程序和功能
我搜索" Microsoft SQL Server 2008 R2 Native Client'
(因为我使用的是Microsoft SQL Server 2008 R2)
它会说,不建议卸载本机客户端,但只要我们安装其他本机客户端就可以了
我下载
" Microsoft SQL Server 2012本机客户端"
并且,它解决了,我不知道发生了什么,我只知道,它有助于我的php应用程序连接到ms sql server 2008 R2