php adodb连接mssql解决乱码问题
2015-01-24信息快讯网
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' 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:[email protected]/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:[email protected]/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>
hadoop中一些常用的命令介绍
hadoop常见错误以及处理方法详解
关于php连接mssql:pdo odbc sql server
php调用mysql数据 dbclass类
PHP操作MongoDB时的整数问题及对策说明
fleaphp crud操作之findByField函数的使用方法
在MongoDB中模拟Auto Increment的php代码
PHP备份/还原MySQL数据库的代码
PHP 设置MySQL连接字符集的方法
PHP中simplexml_load_string函数使用说明
PHP+SQL 注入攻击的技术实现以及预防办法
解决PHP在DOS命令行下却无法链接MySQL的技术笔记
PHP的autoload自动加载机制使用说明
PHP与MySQL开发的8个技巧小结
php header示例代码(推荐)
PHP下利用header()函数设置浏览器缓存的代码
PHP通过header实现文本文件下载的代码
C# Assembly类访问程序集信息
php array_map array_multisort 高效处理多维数组排序
php MsSql server时遇到的中文编码问题
phpMyAdmin 安装配置方法和问题解决
IIS6+PHP5+MySQL5+Zend Optimizer+phpMyAdmin安装配置图文教程 2009年
PHP 批量删除 sql语句
phpMyAdmin 安装及问题总结
PHP XML备份Mysql数据库
PHPMyAdmin 快速配置方法
PHP SQLite类
php adodb分页实现代码
php daodb插入、更新与删除数据
php adodb连接不同数据库
php adodb操作mysql数据库
php adodb介绍
php adodb连接带密码access数据库实例,测试成功