PHP连接SQL Server 2005 和 SQL Server 2008

原创 2011年01月12日 16:05:00

一环境配置:

  因为我自己机器是Windows 2008 + SQL Server 2008,所以我在使用的时候连接的是SQL Server 2008,后来发现基本功能两个版本区别不大,因为三方驱动都是微软提供的。需要说明的是,在PHP配置文件,即原生的php.ini里面需要修改一点东西,我没有尝试过去掉下边的注释是否可以访问05和08的数据库:

;extension=php_mssql.dll

  我查阅了网上很多资料,这个PHP扩展是提供给SQL Server 2000用的,SQL   Server 2005和 SQL Server 2008需要到微软官方去下载新的驱动,下载地址如下:


  官方文档有描述:

  In its continued commitment to interoperability, Microsoft has released an updated SQL Server Driver for PHP. The SQL Server Driver for PHP download is available to all SQL Server users at no additional charge. The SQL Server Driver for PHP is a PHP 5 extension that allows for the reading and writing of SQL Server data from within PHP scripts. The extension provides a procedural interface for accessing data in all editions of SQL Server 2005 and SQL Server 2008.

  根据官方文档的描述,微软提供的Driver是同时提供给SQL Server 2005和SQL Server 2008两个版本使用的。所以整体的环境配置步骤如下:

1)下载驱动(上边有链接地址)下载过后的驱动包里面的内容如下图:
   
    可以在百度上搜 php_sqlsvr_ts.dll 和 php_sqlsvr.dll 两个文件,如果下不到,也可以联系我:QQ:104689080 或 email:yuyang2009@126.com .

2)拷贝驱动到相应的位置:

  在Windows操作系统上配置过PHP环境的人应该都清楚,配置的时候若需要配置一个PHP的扩展,此扩展需要将相关的dll文件全部复制到PHP的扩展目录里面,然后通过修改php.ini来实现PHP的扩展,在php.ini里面需要指明扩展路径,一般情况是在最末尾添加一行:

extension_dir=""

  ""内的内容填写PHP的扩展目录名,约定俗成一般是放在PHP目录下的一个ext文件夹内,当然可以将目录配置到任何地方(没有测试过)。把上图解压开的dll文件拷贝到extension_dir设置的扩展目录里面。

3)修改php.ini实现扩展:

  在php.ini的一大堆;extension=**.dll格式里面添加两行,此部分位于以下注释下边一般:

; Windows Extensions

; Note that ODBC support is built in, so no dll is needed for it.

; Note that many DLL files are located in the extensions/ (PHP 4) ext/ (PHP 5)

; extension folders as well as the separate PECL DLL download (PHP 5).

; Be sure to appropriately set the extension_dir directive.

  添加的两行内容为:

extension=php_sqlsrv_ts.dll

extension=php_sqlsrv.dll

  注意=号右边是解开过后的扩展的两个驱动的文件名,必须保证此文件在配置好的扩展目录内,而且需要注意此处最初不需要带“;”。【*:在php.ini文件里面,首部分号的含义代表行注释,如果有分号的时候,服务器在读取配置的时候会略过分号这一行不去读取相关内容,只有没有加分号的行才会被服务器读取。】

  这里解释一下,两个驱动程序的区别在于,php_sqlsrv_ts.dll是线程安全的驱动,如果服务器本身的环境是使用的php5ts.dll,就是用这个驱动;php_sqlsrv.dll不是线程 安全的,这种情况下,服务器运行PHP应该加载的是php5.dll

4)测试配置环境:

  整个过程操作好了过后,写一个test.php测试一下配置的相关环境,测试代码如下:

<?php

phpinfo();

?>
  这里列举一下开发环境,以防出现不同环境有差异的地方:

OS:Windows Server 2008   x64 Enterprise Edition

WebServer:Apache 2.2.11

Database:SQL Server 2008   x64 Enterprise Edition

PHP:5.2.9

  (*:在配置PHP环境的时候,如果是解压缩的版本,在Windows平台上需要拷贝PHP根目录下所有的DLL文件到Windows的目录里面,需要说明的是:Windows 32位系统的目标目录为:$:/Windows/System32,Windows 64位环境的目标目录为:$:/Windows/SysWOW64,这里$符号代表安装操作系统的盘符号。而且本文的Driver好像运行的最低PHP版本应该为5.2.6,官方文档里面说的测试版本是使用的PHP5.2.6,至于低版本是否可以运行,我没有测试。)

二连接数据库:

  使用过SQL Server的人应该都清楚,SQL Server常用的有两种认证方式,一种是本地系统账户认证(Windows Authentication ),一种是使用用户名和密码(SQL Server Authentication ),第二种认证方式必须启用SQL Server的混合模式。

  1.Windows Authentication连接部分代码段:

<?php

$serverName = "(local)";

$connectionInfo = array("Database"=>"TestingInfo","ConnectionPooling"=>false);

$conn = sqlsrv_connect( $serverName,$connectionInfo);

if( $conn == false)

{

echo "连接失败!";

die( print_r( sqlsrv_errors(), true));

}

?>

  2.SQL Server Authentication连接部分代码段:

<?php

$serverName = "(local)";

$uid = "sa";

$pwd = "******";

$connectionInfo =   array("UID"=>$uid,"PWD"=>$pwd,"Database"=>"TestingInfo");

$conn = sqlsrv_connect( $serverName,$connectionInfo);

if( $conn == false)

{

echo "连接失败!";

die( print_r( sqlsrv_errors(), true));

}

?>

  参考官方提供的英文原文档,针对参数$connectionInfo做一个简单说明,因为$connectionInfo是一个Hash表结构,下边参数格式为:

Key[DataType]:

Description(Default Value):键[数据类型]:描述(默认值)

【1】APP[String类型]:

使用的应用程序名称【*:我自己不太懂得这个地方的意义,不好意思】(没有默认值)

【2】ConnectionPooling[1或true为打开连接池,0或false为关闭连接池]:

用来设置是否打开SQL Server的连接池功能(默认值为true(1))

【3】Database[String类型]:

连接的数据库的名称,所有连接提供的数据库名称类似ASP.NET里面web.config的连接字符串里面的数据库实例名,如果设置了Database的连接属性,驱动会默认使用SQL Server支持的Transact-SQL脚本来操作所有提供的数据库实例,包括添加、删除、查询、修改等各种操作(默认为登陆的操作系统里面的数据库,我没有测试过,应该是直接运行程序的(local))

【4】Encrypt[1或true为执行加密,0或false为不执行加密]:

设置是否对传入服务器的SQL脚本执行加密操作,当然如果使用加密操作会对系统性能存在一定影响,不过影响不明显(默认为false(0))

【5】Failover_Partner[String类型]:

提供一个服务器镜像,此属性应该是用于主服务器Down掉的情况,当主服务器Down掉的时候,提供一个备份的数据库和服务器的实例镜像作为备份的服务器处理。(未设置默认值)

【6】LoginTimeout[Integer类型]:

提供连接的超时时间,时间单位为秒。(未设置)

【7】PWD[String类型]:

当使用SQL Server Authentication认证方式的时候需要提供该属性,该属性为登陆用户的密码。(未设置任何值)

【8】QuotedId[1或true就是用SQL-92标准,0或false就是用遗留的标准]:

设置使用SQL脚本的标准是使用SQL-92标准还是使用遗留的Transact-SQL标准。(默认值为true(1))

【9】TraceFile[String类型]:

此属性主要为监控数据使用,可用于调试或者维护,它的值为一个路径,SQL Server会将所有的数据执行操作写入该路径,至于具体内容是什么,我没有使用过。(未设置默认值)

【10】TraceOn[1或true打开监控,0或false关闭监控]:

是否打开ODBC连接方式的监控。(默认值false(0))

【11】TransactionIsolation[常量值]:

提供数据库的事务级别(SQLSRV_TXN_READ_COMMITTED)

常量值包括

SQLSRV_TXN_READ_UNCOMMITTED,

SQLSRV_TXN_READ_COMMITTED,

SQLSRV_TXN_REPEATABLE_READ,

SQLSRV_TXN_SNAPSHOT,

SQLSRV_TXN_SERIALIZABLE

【12】TrustServerCertificate[1或true设置为客户端限制,0或false设置为客户端不限制]:

如果设置为 true,则使用 SSL 对通道进行加密,但不通过证书链对可信度进行验证。如果将TrustServerCertificate 设置为 true 并将 Encrypt 设置为 false,则不对通道进行加密。可识别的值为 true、false、yes 和 no。有关更多信息,请参见 SQL Server 2005 Books Online(《SQL Server 2005 联机丛书》)中的“Encryption Hierarchy”(加密层次结构)和“Using Encryption Without Validation”(使用不验证的加密)。(默认值:false(0))

【13】UID[String类型]:

当使用SQL Server Authentication认证方式的时候需要提供该属性,该属性为登陆用户的用户名。(未设置任何值)

【14】WSID[String类型]:

监控计算机名称,此属性很少用。(未设置任何值)

 

以下为微软的示例代码:

<?php
/* Connect to the local server using Windows Authentication and
specify the AdventureWorks database as the database in use. */
$serverName = "(local)";
$connectionInfo = array( "Database"=>"AdventureWorks");
$conn = sqlsrv_connect( $serverName, $connectionInfo);
if( $conn === false )
{
     echo "Could not connect./n";
     die( print_r( sqlsrv_errors(), true));
}

/* Set up and execute the query. */
$tsql = "SELECT FirstName, LastName FROM Person.Contact WHERE LastName='Alan'";
$stmt = sqlsrv_query( $conn, $tsql);
if( $stmt === false)
{
     echo "Error in query preparation/execution./n";
     die( print_r( sqlsrv_errors(), true));
}

/* Retrieve each row as an associative array and display the results.*/
while( $row = sqlsrv_fetch_array( $stmt, SQLSRV_FETCH_ASSOC))
{
      echo $row['LastName'].", ".$row['FirstName']."/n";
}

/* Free statement and connection resources. */
sqlsrv_free_stmt( $stmt);
sqlsrv_close( $conn);
?>

参考链接:

http://technet.microsoft.com/zh-cn/library/cc296174(SQL.90).aspx

相关文章推荐

配置SQL Server 2008(2005)允许远程连接

配置SQL Server 2008(2005)允许远程连接 防火墙的配置 尤其重要,很多情况都是防火墙没配置好...
  • sage425
  • sage425
  • 2011年03月26日 10:01
  • 2855

已安装sql server 2005的电脑上安装Sql server 2008相关

在项目开发过程中安装一个Sql server 2005,但是需要用到sql server 2008 ,因此需要在电脑上在安装一个Sql server 2005,通过网上查阅相关资料,发现两者并存可行,...
  • herb777
  • herb777
  • 2013年01月05日 15:21
  • 4916

WINDOWS XP安装了SQL Server 2005 Express后再安装VS自带的SQL Server 2008步骤

一、电脑已经安装了SQL Server 2005 Express,再安装VS 2010自带的SQL Server 2008时没有找到SQL Server Management Studio这个图形界面...
  • k_woon
  • k_woon
  • 2015年05月21日 23:45
  • 365

从SQL Server 2000/2005到SQL Server 2008的升级测试

 转自:http://www.cnblogs.com/romance/articles/1849871.html      本文部分内容摘自《SQL Server 2008管理实战》,人民邮电出版社;...

如何转换为SQL Server 2008r2数据库到SQL Server 2005

1)  2)  3)  4) 'Script for Server Version' = 'SQL Server 2005' 'Script Data' = 'True...
  • hybaym
  • hybaym
  • 2014年02月08日 18:07
  • 1628

PHP5.6.15连接Sql Server 2008配置方案

PHP5.6.15连接Sql Server 2008配置方案 php5.6的如果想连接Sql Server 2008数据库,需要手动配置扩展和安装一个驱动。 下载SQL Server Driver ...

关于PHP5.6连接SQL Server 2008 R2数据库驱动及一些问题

今天因为一些原因,接触到了php连接MSSQL2008的问题,自己毕竟第一次接触,出了不少洋相,然后根据自己查阅资料学习等等,终于搞定了这个事情,因为在网上没找到一篇完整像样的文章,所以写了这一篇文章...

远程连接SQL Server 2005/2008,服务器端和客户端配置

(1)这里只指出关键设置步骤,其他详细部分网上到处都是,不赘述; (2)感谢http://blog.csdn.net/htl258/archive/2010/03/28/5424234.aspx,给...

关于Java图形化连接微软SQL server(含2005,2008,2012等)数据库的问题

关于Java连接数据库(SQL server,Oracle,Mysql等)基本的汇总。新人第一篇博文,有很多不足之处,请见谅,请提议。...

[SQL Server 2005/2008]专用管理员连接(DAC)

dedicated administrator connection (DAC)  : 管理员专用连接。       当SQL Server因系统资源不足,或其它异常导致无法建立数据库连接时, 可以使...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:PHP连接SQL Server 2005 和 SQL Server 2008
举报原因:
原因补充:

(最多只允许输入30个字)