我无法通过COM库与PHP连接到MS SQL2000。 我得到的信息是:
无法建立数据库连接异常'com_exception' 消息'源:用于ODBC驱动程序的Microsoft OLE DB提供程序 说明:[Microsoft] [ODBC SQL Server驱动程序] [DBMSLPCN] SQL Server 不存在或访问被拒绝.....
我已阅读了很多帖子,但未能找到任何直接的示例如何设置PHP以便轻松连接。这是我到目前为止采取的步骤:
1)在启用TCP / IP和命名管道的情况下运行MSSQL2000,侦听端口1433 2)安装PHP版本5.4.16 TS 3)我启用了以下扩展(与mssql相关):
extension=php_com_dotnet.dll
extension=php_pdo_sqlsrv_53_ts_vc9.dll
extension=php_sqlsrv_53_ts_vc9.dll
extension=php_pdo_mssql.dll
extension=php_pdo_odbc.dll
4)我检查了COM windows permissions 5)我确信我已经为连接字符串提供了正确的数据库/实例,用户名和密码。 6)当我使用:
实例化COM对象时$connection = new COM("ADODB.Connection");
print_r($connection);
...我得到“com Object”输出响应,这意味着该类似乎工作正常。
我忽略了什么?我必须通过ADODB连接,因为我正在开发的整个站点都是基于它构建的。有没有办法调试这个?任何帮助表示赞赏。
答案 0 :(得分:0)
问题解决了!
经过几天的解决,并重新安装几乎所有的东西,包括Apache,不同的PHP和MSSQL版本,我提出了以下内容。我并不认为这是最好的解决方案,但它有效:
功能环境:
1)带有MSSQL 2012的Windows Azure服务器
2)Apache 2.2 PHP 5.3.28 - 安装程序:php-5.3.28-Win32-VC9-x86.msi从以下位置下载: http://windows.php.net/download/
PHP扩展程序(我列出了所有内容,但只需要最后几个):
[PHP_BZ2]
extension=php_bz2.dll
[PHP_CURL]
extension=php_curl.dll
[PHP_ENCHANT]
extension=php_enchant.dll
[PHP_FILEINFO]
extension=php_fileinfo.dll
[PHP_GD2]
extension=php_gd2.dll
[PHP_GETTEXT]
extension=php_gettext.dll
[PHP_GMP]
extension=php_gmp.dll
[PHP_IMAP]
extension=php_imap.dll
[PHP_INTL]
extension=php_intl.dll
[PHP_LDAP]
extension=php_ldap.dll
[PHP_MBSTRING]
extension=php_mbstring.dll
[PHP_MYSQL]
extension=php_mysql.dll
[PHP_MYSQLI]
extension=php_mysqli.dll
[PHP_OCI8]
extension=php_oci8.dll
[PHP_OCI8_11G]
extension=php_oci8_11g.dll
[PHP_OPENSSL]
extension=php_openssl.dll
[PHP_PDO_MYSQL]
extension=php_pdo_mysql.dll
[PHP_PDO_OCI]
extension=php_pdo_oci.dll
[PHP_PDO_ODBC]
extension=php_pdo_odbc.dll
[PHP_PDO_PGSQL]
extension=php_pdo_pgsql.dll
[PHP_PDO_SQLITE]
extension=php_pdo_sqlite.dll
[PHP_PGSQL]
extension=php_pgsql.dll
[PHP_SHMOP]
extension=php_shmop.dll
[PHP_SNMP]
extension=php_snmp.dll
[PHP_SOAP]
extension=php_soap.dll
[PHP_SOCKETS]
extension=php_sockets.dll
[PHP_SQLITE]
extension=php_sqlite.dll
[PHP_SQLITE3]
extension=php_sqlite3.dll
[PHP_SYBASE_CT]
extension=php_sybase_ct.dll
[PHP_TIDY]
extension=php_tidy.dll
[PHP_XMLRPC]
extension=php_xmlrpc.dll
[PHP_XSL]
extension=php_xsl.dll
[PHP_EXIF]
extension=php_exif.dll
php_sqlsrv_53_ts_vc9.dll
php_pdo_sqlsrv_53_ts_vc9.dll
extension=php_com_dotnet.dll
从以下网址下载了php_pdo_sqlsrv_53_ts_vc9.dll扩展包: http://www.microsoft.com/en-us/download/details.aspx?id=20098
从以下位置下载的扩展名= php_com_dotnet.dll: http://originaldll.com/file/php_com_dotnet.dll/29343.html(无法验证此文件的安全性但是有效)
MSSQL 2012需要设置如下:
创建数据库时,打开管理工作室并右键单击左侧树中的数据库实例。确保在 properties-> security 标签下选择:“SQL Server和Windows身份验证模式”。如果您使用标准的用户名/密码方法,如果没有这个,您将永远无法连接。
然后继续创建数据库模式,并在主安全选项卡下创建具有与此数据库相关的用户名/密码的新用户。确保您设置了所有权限,例如:所有者,datareader,数据编写者。
我使用的PHP连接脚本如下: * ============================================== = *
function openConnection() {
$dbaseServer = "instance name";
$dbaseIp = "127.0.0.1";
$dbasePort = "1433";
$dbaseName = "databsse name";
$dbaseUser = "username";
$dbasePassword = "password";
$connectionString = ""
."Driver={SQL Server};"
."Network=DBMSSOCN;"
."Server=$dbaseServer;"
."Address=$dbaseIp:$dbasePort;"
."Database=$dbaseName;"
."Uid=$dbaseUser;"
."Pwd=$dbasePassword";
try {
$connection = new COM("ADODB.Connection");
$connection->ConnectionTimeout = 60;
$connection->Open($connectionString);
return $connection;
} catch (exception $e) {
echo "Could not connect - $e";
exit;
}
}
// test query
//===========
$sql = "SELECT * FROM [dbname].[dbo].[tablename]";
$connection = openConnection();
// unnecessary but in my case more time is needed.
$connection->CommandTimeout = 240;
$recordset = $connection->Execute($sql);
if (!$recordset) { $connection->Close(); die("Request failed!"); }
if (!$recordset->EOF) {
while (!$recordset->EOF) {
$test[] = $recordset[0]->value;
$recordset->MoveNext();
}
}
print_r($test);
$connection->Close();
-
我认为就是这样。请随时更正我的帖子和/或改进它:)