PHP   发布时间:2019-11-12  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了PHP 5.6.11 访问SQL Server2008R2的几种情况详解大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。

php天生支持MySQL,但是有时候也想让它访问SQL Server,该怎么办呢?

最近找了点资料,测试成功了php访问SQLSvr的几种情况,限于时间,还没有测试更多不同环境,把测试过的记录如下:

测试环境:win7 x64 sp1,IIS 7.5,Apache 2.4 32位版本,php 5.2.6 win32,php 5.6.11 win32 ts(线程安全版)

注:由于“MIcrosoft Drivers for php for SQL Server”驱动程序目前只有32位版,所以如果是使用sql server数据库的朋友,不建议使用php 64位,否则会导致无法连接 sql server 数据库的问题!

php 5.2.6在iis上成功访问了sql2000

php 5.2.6在iis上成功访问了sql2008r2

php 5.6.11在apache上成功访问了sql2008r2

【5.2.6 -> SQL2000】

为什么要用5.2.6这么旧的php版本做测试呢,因为php 5.2版本,内置了php_mssql.dll 模块,

打开了php.ini中的extension=php_mssql.dll 配置选项,默认好像就支持mssql2000了,

打开phpinfo能看到相关的支持模块内容:

PHP 5.6.11 访问SQL Server2008R2的几种情况详解

Ps.IIS 7.0下安装php现在方便了,可以通过一个第三方小工具 php Manager来安装,也可以方便的切换iis下的php版本,这不是本文的主要内容,这里就不介绍了;

php manager for iis 7 下载安装地址: /

PHP 5.6.11 访问SQL Server2008R2的几种情况详解

PHP 5.6.11 访问SQL Server2008R2的几种情况详解

写一个测试的小例程:

"; } ?>

在IIS 7.5下运行结果如下:成功!

PHP 5.6.11 访问SQL Server2008R2的几种情况详解

【5.6.11 -> SQL2008R2】

5.6以上的PHP已经没有php_mssql.dll,貌似也不再原生支持sql2000以上版本的sql server了,要通过第三方模块,在微软官网找到了:

Microsoft Drivers for PHP for SQL Server

下载链接地址有四个文件:

•SQLSRV30.EXE •SQLSRV31.EXE •SQLSRV32.EXE •SQLSRV40.EXE

分别支持不同的php版本

•Version 4.0 supports php 7.0+ •Version 3.2 supports php 5.6,5.5,and 5.4 •Version 3.1 supports php 5.5 and 5.4 •Version 3.0 supports php 5.4.

如果是php 5.2要下载一个SQLSRV20.EXE,这个文件目前在网上也能很容易的找到;

然5.2这么旧的版本早就该被淘汰了,但是虑到某些环境还需要用它)

php_pdo_sqlsrv_52_ts_vc6.dll

php_sqlsrv_52_ts_vc6.dll

PHP 5.6.11 访问SQL Server2008R2的几种情况详解

1. 我手里是php 5.6.11 win32 ts,要用到这个

php_sqlsrv_56_ts.dll php_pdo_sqlsrv_56_ts.dll

这两个文件,复制到php\ext目录下,

2. php.ini 里加上以下两句:

extension=C:\php5\ext\php_sqlsrv_56_ts.dll extension=C:\php5\ext\php_pdo_sqlsrv_56_ts.dll

3. 重启IIS或者Apache,

4. 通过phpinfo能够看到如下模块显示,我们的php应该此时就能访问SQL Server 2008R2了;

PHP 5.6.11 访问SQL Server2008R2的几种情况详解

PHP 5.6.11 访问SQL Server2008R2的几种情况详解

5、写一个小程序验证一下:

php;"> php try { $dbname = "sqlsrv:Server=127.0.0.1\sql2008r2;Database=master"; $dbUser = "sa"; $dbpassword = "yoooko"; $db = new PDO($dbName,$dbUser,$dbpassword); if ($db) { echo "database connect succeed.
"; } } catch (PDOException $E) { $content = iconv("UTF-8","gbk",$e->getmessage()); echo $content . "
"; } //echo "Hello PDO to MS SqlSrv!"; ?>@H_616_84@

如果出现如下提示:

PHP 5.6.11 访问SQL Server2008R2的几种情况详解

可能你还需要安装 Microsoft® ODBC Driver 11 for SQL Server® - Windows

下载地址:https://www.microsoft.com/zh-cn/download/details.aspx?id=36434">https://www.microsoft.com/zh-cn/download/details.aspx?id=36434

PHP 5.6.11 访问SQL Server2008R2的几种情况详解

如果正确的话,应该就OK了:

Ps.由于新的模块是通过PDO方式访问SQL Server 2008R2,如果是本机访问,那么直接通过ip地址和sa账号就能访问了,

如果php和sql2008r2在不同电脑上,还得设置TCP 端口1433来访问,见下面第二张图,把动态端口改为0,把端口设置为14333如果你的SQL2000已经占用了1433,访问地址后面加个,xxxx端口号

sqlsrv:Server=192.168.1.xxx\sql2008r2,14333;Database=master

@H_618_115@

PHP 5.6.11 访问SQL Server2008R2的几种情况详解

以上所述是小编给大家介绍的php 5.6.11 访问SQL Server2008R2的几种情况详解。菜鸟教程 jb51.cc 收集整理的教程希望能对你有所帮助,如果觉得菜鸟教程不错,可分享给好友!感谢支持。

大佬总结

以上是大佬教程为你收集整理的PHP 5.6.11 访问SQL Server2008R2的几种情况详解全部内容,希望文章能够帮你解决PHP 5.6.11 访问SQL Server2008R2的几种情况详解所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。