PHP 连接 MSSQL 2005/2008 以UTF8存取 并让ADODB支持的安装设置
2010-11-14 19:27
831 查看
因系统大量使用AJAX,为避免编码转来转去的麻烦,把文件都设为了UTF8。但在操作MSSQL时遇到乱码问题,查阅一番后原来是MSSQL不支持UTF8,寒~~ 花了一天时间来处理这个问题,并最终解决:
一、安装SQL Server Driver for PHP
在微软官网上发现了这个东西,他提供了一套PHP对MS2005/2008操作的全新函数库,并且支持UTF8,作为PHP的扩展运行。看来MS对PHP还比较亲善,PHP自带的mssql操作函数对MS2005/2008的一些新功能不支持,MS就自己提供了解决方法,赞一个!不过只支持PHP5.2/5.3,MS说目前在PHP 5.2上测试过,低版本的是否支持就不清楚了。我的系统正好也用的是PHP5.2,其它版本也懒得去测了。
下载地址:http://www.microsoft.com/downloads/details.aspx?familyid=CCDF728B-1EA0-48A8-A84A-5052214CAAD9&displaylang=en
下载后是个.exe的压缩包,解开后有下列.dll文件:
php_sqlsrv_52_nts_vc6.dll
php_sqlsrv_52_ts_vc6.dll
php_sqlsrv_53_nts_vc6.dll
php_sqlsrv_53_nts_vc9.dll
php_sqlsrv_53_ts_vc6.dll
php_sqlsrv_53_ts_vc9.dll
要根据自己的PHP环境选择一个合适的.dll,压缩包的说明文档给出了适用范围:
DLL名字称中的_vc6/_vc9表示你使用的PHP为vc6或vc9编译,PHP version中确定适用版本,Thread safe为该版本安全性,Use with PHP .dll是你PHP的安装方式。更多说明请参考文档。
我这里选择的是php_sqlsrv_52_ts_vc6.dll,拷贝到php/ext/下,然后在php.ini中添加一行“extension=php_sqlsrv_52_ts_vc6.dll”,重启WEB服务。phpinfo();查看一下,如果有“sqlsrv”扩展项,就表示安装成功了。
二、安裝Microsoft SQL Server Native Client
这个是MSSQL的客户端存取程序,它提供了ODBC、OLE DB、ADO 等方式连接 MSSQL。 如果已经安装了MSSQL2005/2008,则已经安装了对应版本的此程序,不用单独安装了。
Microsoft SQL Server Native Client 2005支持SQL Server 7、2000、2005
下载地址:http://www.microsoft.com/downloads/details.aspx?displaylang=zh-cn&FamilyID=50b97994-8453-4998-8226-fa42ec403d17,找到对应项后根据自己机器情况(X86/X64)选择下载。
Microsoft SQL Server Native Client 2008支持SQL Server 2000、2005、2008
下载地址:http://www.microsoft.com/downloads/details.aspx?displaylang=zh-cn&FamilyID=c6c3e9ef-ba29-4a43-8d69-a2bed18fe73c,找到对应项后根据自己机器情况(X86/X64/IA64)选择下载。
三、至此已经可以使用UTF8进行存取了
新建一个UTF8编码的文件,测试一下:
四、ADODB支持
看到上例可能要抓狂了,因为提供了全新的一套操作函数,使用起来不习惯,跟现有系统也不兼容。去下载了个最新版的ADODB后惊喜的发现它已经封装了该系列函数,帮我们解决了此问题。只需作个简单的修改:
找到/adodb/drivers/adodb-mssqlnative.inc.php,在_connect方法后有一行:
“ $connectionInfo = array("Database"=>$argDatabasename,'UID'=>$argUsername,'PWD'=>$argPassword);”
改为:
“ $connectionInfo = array("Database"=>$argDatabasename,'UID'=>$argUsername,'PWD'=>$argPassword,"CharacterSet" => 'UTF-8');”
ADODB下载:http://adodb.sourceforge.net
OK了,测试代码:
一、安装SQL Server Driver for PHP
在微软官网上发现了这个东西,他提供了一套PHP对MS2005/2008操作的全新函数库,并且支持UTF8,作为PHP的扩展运行。看来MS对PHP还比较亲善,PHP自带的mssql操作函数对MS2005/2008的一些新功能不支持,MS就自己提供了解决方法,赞一个!不过只支持PHP5.2/5.3,MS说目前在PHP 5.2上测试过,低版本的是否支持就不清楚了。我的系统正好也用的是PHP5.2,其它版本也懒得去测了。
下载地址:http://www.microsoft.com/downloads/details.aspx?familyid=CCDF728B-1EA0-48A8-A84A-5052214CAAD9&displaylang=en
下载后是个.exe的压缩包,解开后有下列.dll文件:
php_sqlsrv_52_nts_vc6.dll
php_sqlsrv_52_ts_vc6.dll
php_sqlsrv_53_nts_vc6.dll
php_sqlsrv_53_nts_vc9.dll
php_sqlsrv_53_ts_vc6.dll
php_sqlsrv_53_ts_vc9.dll
要根据自己的PHP环境选择一个合适的.dll,压缩包的说明文档给出了适用范围:
Driver file | PHP version | Thread safe? | Use with PHP .dll |
php_sqlsrv_53_nts_vc6.dll | 5.3 | no | php5.dll |
php_sqlsrv_53_nts_vc9.dll | 5.3 | no | php5.dll |
php_sqlsrv_53_ts_vc6.dll | 5.3 | yes | php5ts.dll |
php_sqlsrv_53_ts_vc9.dll | 5.3 | yes | php5ts.dll |
php_sqlsrv_52_nts_vc6.dll | 5.2 | no | php5.dll |
php_sqlsrv_52_ts_vc6.dll | 5.2 | yes | php5ts.dll |
我这里选择的是php_sqlsrv_52_ts_vc6.dll,拷贝到php/ext/下,然后在php.ini中添加一行“extension=php_sqlsrv_52_ts_vc6.dll”,重启WEB服务。phpinfo();查看一下,如果有“sqlsrv”扩展项,就表示安装成功了。
二、安裝Microsoft SQL Server Native Client
这个是MSSQL的客户端存取程序,它提供了ODBC、OLE DB、ADO 等方式连接 MSSQL。 如果已经安装了MSSQL2005/2008,则已经安装了对应版本的此程序,不用单独安装了。
Microsoft SQL Server Native Client 2005支持SQL Server 7、2000、2005
下载地址:http://www.microsoft.com/downloads/details.aspx?displaylang=zh-cn&FamilyID=50b97994-8453-4998-8226-fa42ec403d17,找到对应项后根据自己机器情况(X86/X64)选择下载。
Microsoft SQL Server Native Client 2008支持SQL Server 2000、2005、2008
下载地址:http://www.microsoft.com/downloads/details.aspx?displaylang=zh-cn&FamilyID=c6c3e9ef-ba29-4a43-8d69-a2bed18fe73c,找到对应项后根据自己机器情况(X86/X64/IA64)选择下载。
三、至此已经可以使用UTF8进行存取了
新建一个UTF8编码的文件,测试一下:
$connstr = array("Database"=>"test","Uid"=>"sa","Pwd"=>"xxx","CharacterSet" => "UTF-8"); $conn = sqlsrv_connect('127.0.0.1',$connstr); if($conn==false) print_r(sqlsrv_errors(),true); $sql = "SELECT TOP 10 * FROM table"; if($data = sqlsrv_query($conn, $sql)) { while($row = sqlsrv_fetch_array($data,SQLSRV_FETCH_ASSOC)) { print_r($row); } } sqlsrv_close($conn); |
看到上例可能要抓狂了,因为提供了全新的一套操作函数,使用起来不习惯,跟现有系统也不兼容。去下载了个最新版的ADODB后惊喜的发现它已经封装了该系列函数,帮我们解决了此问题。只需作个简单的修改:
找到/adodb/drivers/adodb-mssqlnative.inc.php,在_connect方法后有一行:
“ $connectionInfo = array("Database"=>$argDatabasename,'UID'=>$argUsername,'PWD'=>$argPassword);”
改为:
“ $connectionInfo = array("Database"=>$argDatabasename,'UID'=>$argUsername,'PWD'=>$argPassword,"CharacterSet" => 'UTF-8');”
ADODB下载:http://adodb.sourceforge.net
OK了,测试代码:
$conn = ADONewConnection('mssqlnative'); $conn->Connect(DB_HOST,DB_USER,DB_PASS,DB_NAME); $ADODB_FETCH_MODE= ADODB_FETCH_ASSOC; $sql = "SELECT * FROM table"; $data = $conn->GetAll($sql); print_r($data); |
相关文章推荐
- centOS 6通过yum安装php-mssql以使php支持microsoft sql server连接
- 2008下如何快速安装PHP,并做好安全设置
- mssql for php 安装 适用于 mssql 2005
- php使用开源的adodb连接mssql解决乱码问题
- linux编译安装mssql客户端和配置php连接mssql
- win2008 r2 安装sql server 2005/2008 无法连接服务器解决方法
- PHP连接SqlServer2008,需要安装mssql,freetds模块(yum安装方式)
- 使用JDBC连接MSSQL数据库中2000/2005/2008的区别
- PHP连接SQL Server 2005 和 SQL Server 2008
- PHP连接mssql 2005 输出json并处理中文乱码方法
- win2008 r2 安装sql server 2005/2008 无法连接服务器解决方法
- SQL Server 2005(2008)安装过程中忘记设置sa用户的解决方案和远程访问
- linux连接mssql数据库,在Centos7下为PHP安装mssql扩展
- 使用JDBC连接MSSQL数据库中2000/2005/2008的区别
- php5.3.x连接sql server 2005 (php5.3连接mssql)
- 使用JDBC连接MSSQL数据库中2000/2005/2008的区别
- PHP连接Microsoft SQL Server 2000/2005/2008
- 工作总结之PHP连接Microsoft SQL Server 2000/2005/2008
- php 5.3连接mssql2005以上版本的数据库