php使用开源的adodb连接mssql解决乱码问题
2009-06-12 17:44
831 查看
周海汉/文
php程序是utf-8的,sqlserver是2005中文,内码是gb18030. 普通的mssql_connect无法设置内码转换,读出来的数据在utf-8页面显示乱码。ADO可以用 new COM("ADODB.Connection", NULL, CP_UTF8)//65001 这样的语句来实现正确转换。但ADO对php的支持缺乏文档。而有个开源的adodb,文档较为丰富。
其中对不同数据库驱动,设置UTF-8的方法还不一样,如下:
其中,Ado可以使用charPage这个属性来设置uft-8,类似new COM的方式。但发现当将AdoNewConnection($dbdriver)的$dbdriver设为'ado'或'ado_mssql'时,其传进去的database被替换为provider。那database的名字如何设置呢?一直没找到办法。
$dbdriver='ado://sa:cvttdev@172.16.22.40/sqloledb?charpage=65001';
其格式是'driver://user:passwd@host/database?options[=value]
但没解决设置数据库名字的地方。
痛苦了很久,只能找到如下的办法解决:
php程序是utf-8的,sqlserver是2005中文,内码是gb18030. 普通的mssql_connect无法设置内码转换,读出来的数据在utf-8页面显示乱码。ADO可以用 new COM("ADODB.Connection", NULL, CP_UTF8)//65001 这样的语句来实现正确转换。但ADO对php的支持缺乏文档。而有个开源的adodb,文档较为丰富。
其中对不同数据库驱动,设置UTF-8的方法还不一样,如下:
For all drivers 'persist', 'persistent', 'debug', 'fetchmode', 'new' Interbase/Firebird 'dialect','charset','buffers','role' M'soft ADO 'charpage' MySQL 'clientflags' MySQLi 'port', 'socket', 'clientflags' Oci8 'nls_date_format','charset'
其中,Ado可以使用charPage这个属性来设置uft-8,类似new COM的方式。但发现当将AdoNewConnection($dbdriver)的$dbdriver设为'ado'或'ado_mssql'时,其传进去的database被替换为provider。那database的名字如何设置呢?一直没找到办法。
$dbdriver='ado://sa:cvttdev@172.16.22.40/sqloledb?charpage=65001';
其格式是'driver://user:passwd@host/database?options[=value]
但没解决设置数据库名字的地方。
痛苦了很久,只能找到如下的办法解决:
<html> <head> <META HTTP-EQUIV="Content-Type" CONTENT="text/html; charset=utf-8"> </head> <body> <?php $dbdriver='ado_mssql'; $server='192.168.22.40'; $user='sa'; $password='passwd'; $DATABASE='sugarcrm_db'; $database='sqloledb'; //$dbdriver='ado://sa:cvttdev@172.16.22.40/sqloledb?charpage=65001'; $myDSN="PROVIDER=MSDASQL;DRIVER={SQL Server};SERVER={172.16.22.40};DATABASE=sugarcrm_db;UID=sa;PWD=cvttdev;"; include('adodb5/adodb.inc.php'); $db = ADONewConnection($dbdriver); # eg 'mysql' or 'postgres' $db->debug = true; $db->charPage =65001; //$db->Connect($server, $user, $password, $database); $db->Connect($myDSN); //error:mssql server not support codes below //$db->Execute("set names 'utf8'"); echo "before query"; $rs = $db->Execute('select * from accounts'); print "<pre>"; print_r($rs->GetRows()); print "</pre>"; ?> </body> </html>
相关文章推荐
- 使用SQL Server Driver for PHP解决PHP连接MSSQL乱码的问题
- php adodb连接mssql解决乱码问题
- LINUX下php连接mssql数据库中文字符乱码问题解决
- 解决用PHP连接狗日的SQLSERVER不能使用UTF8,导致乱码的问题
- PHP使用PDO操作数据库的乱码问题解决方法
- php中json在使用过程中的中文乱码问题解决
- 解决PHP使用CVS导出Excel乱码问题
- 【PHP问题大全】--PHP连接MySQL出现乱码的编码解决办法
- Delphi7使用MyODBC连接Mysql乱码问题解决
- PHP 解决采集乱码问题mb_convert_encoding和iconv使用比较 by cubeking
- php JpGraph 使用完美解决中文乱码问题
- linxu下php使用pdo-dblib连接mssql报错解决方法 错误信息:SQLSTATE[01002]Adaptive Server connection failed (severity 9)
- PHP使用之上传文件到本地服务器(实现上传文件后页面内容不动、解决上传文件命名乱码后缀问题)
- 解决PHP使用普通账号连接mongodb报错问题
- php中json在使用过程中的中文乱码问题解决
- mysql导入导出数据中文乱码解决方法小结(1、navicat导入问题已解决,创建连接后修改连接属性,选择高级->将使用Mysql字符集复选框去掉,下拉框选择GBK->导入sql文件OK;2、phpmyadmin显示乱码的问题也解决,两步:1.将sql文件以utf8的字符集编码另存,2.将文件中sql语句中的字段字符集编码改成utf8,导入OK)
- 解决php5.6连接64位系统下mssql2008的错误问题
- 转载--Delphi 2010下使用sqlitesimpledelphi连接SQLite数据库及中文乱码问题的解决
- php中使用header在下载时乱码问题解决