1

我已经阅读(并尝试过)我能找到的每一篇文章,但没有运气。phpinfo 不显示 sqlsrv,但 ext 文件夹是正确的(经过测试)并且 dll 在那里。

extension=php_pdo.dll //which I don't think is actually needed for this version
extension=php_sqlsrv_53_nts.dll
extension=php_pdo_sqlsrv_53_nts.dll

它们在 c:/PHP/ext 中
使用 FastCGI,确实重新启动了 IIS 以及整个服务器。
这个版本的 PHP (X86) 和 MSSQL10_50.SQLEXPRESS 已经安装并工作了一年。

Windows Server 2008 R2
PHPINFO
编译器:MSVC9 (Visual C++ 2008)
PHP 扩展构建:API20100525,NTS,VC9

但是,在 PHPINFO 上,我在配置命令中看到了这一点:

"--without-mssql" "--without-pdo-mssql" 

刚刚找到并添加:

extension=php_sqlsrv_30_53_nts_vc9x86.dll
extension=php_pdo_sqlsrv_30_53_nts_vc9x86.dll 

然后:

extension_dir="C:\PHP\ext" 

所以我知道我已经正确安装了 dll

任何帮助将不胜感激 - 到目前为止两天!

4

1 回答 1

0

我最近升级了我的 PHP 和 sqlsrv 驱动程序。这是我为 SQLSRV 部分所做的:

首先,我的 phpinfo() 产生:

PHP Version 5.5.1
System: Windows NT HOSTNAME 6.1 build 7601 (Windows 7 Business Edition Service Pack 1) i586
Build Date: Jul 18 2013 10:37:55 
Compiler: MSVC11 (Visual C++ 2012) 
Architecture: x86 


Configure Command
cscript /nologo configure.js "--enable-snapshot-build" "--enable-debug-pack" "--disable-zts" "--disable-isapi" "--disable-nsapi" "--without-mssql" "--without-pdo-mssql" "--without-pi3web" "--with-pdo-oci=C:\php-sdk\oracle\instantclient10\sdk,shared" "--with-oci8=C:\php-sdk\oracle\instantclient10\sdk,shared" "--with-oci8-11g=C:\php-sdk\oracle\instantclient11\sdk,shared" "--with-enchant=shared" "--enable-object-out-dir=../obj/" "--enable-com-dotnet=shared" "--with-mcrypt=static" "--disable-static-analyze" "--with-pgo" 

然后我将 SQLSRV 驱动安装到 C:\Program Files (x86)\PHP\ext 文件中,并在 php.ini 中添加:

[PHP_SQLSRV]
extension=php_sqlsrv_53_nts_vc9.dll 
[PHP_PDOSQLSRV]
extension=php_pdo_sqlsrv_53_nts_vc9.dll

它有效。虽然我不直接调用函数(我使用 Yii 框架),但我也更改了 DSN:

sqlsrv:Server=hostname_or_ip;Database=your_database_name;

希望能帮助到你。

编辑

我从http://social.msdn.microsoft.com/Forums/sqlserver/en-US/e1d37219-88a3-46b2-a421-73bfa33fe433/unofficial-php-55-drivers-x86下载了 PHP 5.5 的实验性/非官方 sqlsrv 驱动程序并将我的配置更新为:

[PHP_SQLSRV]
extension=php_sqlsrv_55_nts.dll 
[PHP_PDOSQLSRV]
extension=php_pdo_sqlsrv_55_nts.dll

发现自:https ://stackoverflow.com/a/17390741/2236500

于 2013-08-09T15:37:07.697 回答