php drive mssql,PHP 连接 MSSQL 2005/2008 以UTF8存取 并让ADODB支持的安装设置
时间:2009-11-9 11:14
作者:欣然随风
因系统大量使用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,其它版本也懒得去测了。
下载地址:
下载后是个.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
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
下载地址:,找到对应项后根据自己机器情况(X86/X64)选择下载。
Microsoft SQL Server Native Client 2008支持SQL Server 2000、2005、2008
下载地址:,找到对应项后根据自己机器情况(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后惊喜的发现它已经封装了该系列函数,帮我们解决了此问题。只需作个简单的修改:
找到/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下载:
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);
爽了!
五、AD一下
php drive mssql,PHP 连接 MSSQL 2005/2008 以UTF8存取 并让ADODB支持的安装设置相关推荐
- ThinkPHP 连接MSSQL PHP连接MSSQL
1.确定SQL装的时候用的是混合认证模式,或SQL验证模式 2.确定SQL2000装好后已打上SP4补丁 3.把"localhost"换成你的计算机名或是"127.0.0 ...
- php连接mssql数据库的几种方式
数据库查询不外乎4个步骤,1.建立连接.2.输入查询代码.3.建立查询并取出数据.4.关闭连接. php连接mssql数据库有几个注意事项,尤其mssql的多个版本.32位.64位都有区别. 首先,p ...
- php连接mssql数据库的几种方法,php连接mssql数据库的几种的实现方法
这篇文章主要为大家详细介绍了php连接mssql数据库的几种的实现方法,具有一定的参考价值,可以用来参考一下. 感兴趣的小伙伴,下面一起跟随512笔记的小玲来看看吧! 首先,php.ini文件中;ex ...
- Linux 下用 Python 连接 MSSql Server 2008
Linux 下用 Python 连接 MSSql Server 2008 赖勇浩(http://blog.csdn.net/lanphaday) Keywords:Linux.python.pyodb ...
- php5.3无法加载mysql数据库模块_PHP_php5.3不能连接mssql数据库的解决方法,本文实例讲述了php5.3不能连接m - phpStudy...
php5.3不能连接mssql数据库的解决方法 本文实例讲述了php5.3不能连接mssql数据库的解决方法.分享给大家供大家参考.具体分析如下: 自从php5.3之后系统就不支持mssql_conn ...
- 数据库设置为php5.3,php5.3不能连接mssql数据库的解决方法,php5.3mssql_PHP教程
php5.3不能连接mssql数据库的解决方法,php5.3mssql 本文实例讲述了php5.3不能连接mssql数据库的解决方法.分享给大家供大家参考.具体分析如下: 自从php5.3之后系统就不 ...
- PHP5.3.5如何连接MSSql Server
windows系统下,PHP5.3以上的版本已经不支持mssql扩展,所以如果你需要和sql server通信需要到http://msdn.microsoft.com/en-us/sqlserver/ ...
- php5.3不能连接mssql数据库的解决方法
这篇文章主要介绍了php5.3不能连接mssql数据库的解决方法,针对php5.3之后不支持mssql_connect函数提供了对应的解决方法,具有一定的参考借鉴价值,需要的朋友可以参考下 本文实例讲 ...
- php5.3空间数据库,windows下 php5.3如何连接mssql
因为php5.3以后php官方不再支持php_mssql扩展,那么php5.3以后如何连接mssql呢. 还好,microsoft 推出了一个sqlsrv扩展.安装步骤如下: 注,安装之前请检查你的操 ...
最新文章
- Linux挂载windows中的共享目录步骤及问题解决方案(步骤清晰)
- C语言之加入头文件<stdbool.h>可以使用true和false
- win10自带抓包工具_Win10商店抓包工具(UWP挖掘机)下载 v1.1
- 云服务器搭网站需要买域名吗,买了云服务器还要买域名吗
- 中报行情 锁定四大板块8只高送转潜力股 2011-7-9
- Latex 中文Beamer模板
- wifi连接上不能上网 手机WiFi连接上不能上网的解决办法
- OpenLayers官方教程二:实现简单的地图显示
- mysql打字竖线_如何打出竖线,教你怎样键盘打出竖线?
- LLVM IR转CFG
- 手机投屏电视android限制声音,没有路由器和WiFi,手机投屏电视教程
- 报错:libpng warning: iCCP: cHRM chunk does not match sRGB解决办法
- 通过置换标签的方式给数据集加噪声
- 百度周景博:POI知识图谱的构建及应用
- MathType 6.9 安装提示关闭软件再试一次
- Microsoft Edge浏览器下载文件乱码修复方法
- sql优化的15个小技巧(必知五颗星),面试说出七八个就有了
- ffmpeg 视频无损拼接 和一键拼接方法
- 什么叫linux网络协议栈,我们为什么使用Linux内核的TCP协议栈
- 5G用户比5G手机多2.6亿,工信部坐不住了,要求运营商降价
热门文章
- C/C++ 中长度为0的数组
- 网络开源框架之libevent使用实例
- 数字图像处理实验(3):PROJECT 02-03, Zooming and Shrinking Images by Pixel Replication
- 模式识别机器学习术语
- Python中文分词--jieba的基本使用
- 自建web3 provider服务
- python基础-装饰器
- 安装node-sass运行报错 Module build failed: TypeError: this.getResolve is not a function at Object.loader
- StringBuffer 和 StringBuilder 的 3 个区别!
- docker 安装zookeeper集群