php使用开源的adodb连接mssql解决乱码问题

abloz 2009-06-12
2009-06-12

周海汉/文

php程序是utf-8的,sqlserver是2005中文,内码是gb18030. 普通的mssql_connect无法设置内码转换,读出来的数据在utf-8页面显示乱码。ADO可以用 new COM(“ADODB.Connection”, NULL, CP_UTF8)//65001 这样的语句来实现正确转换。但ADO对php的支持缺乏文档。而有个开源的adodb,文档较为丰富。

其中对不同数据库驱动,设置UTF-8的方法还不一样,如下:


  1. For all drivers
  2. ‘persist’, ‘persistent’, ‘debug’, ‘fetchmode’, ‘new’
    1. Interbase/Firebird
  3. ‘dialect’,’charset’,’buffers’,’role’
    1. M’soft ADO
  4. ‘charpage’
    1. MySQL
  5. ‘clientflags’
    1. MySQLi
  6. ‘port’, ‘socket’, ‘clientflags’
    1. Oci8
  7. ‘nls_date_format’,’charset’
  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]

但没解决设置数据库名字的地方。

痛苦了很久,只能找到如下的办法解决:


  1. </head>
  2. <?php
  3. $dbdriver=’ado_mssql’;
  4. $server=’192.168.22.40’;
  5. $user=’sa’;
  6. $password=’passwd’;
  7. $DATABASE=’sugarcrm_db’;
  8. $database=’sqloledb’;
  9. //$dbdriver=’ado://sa:cvttdev@172.16.22.40/sqloledb?charpage=65001’;
  10. $myDSN=”PROVIDER=MSDASQL;DRIVER={SQL Server};SERVER={172.16.22.40};DATABASE=sugarcrm_db;UID=sa;PWD=cvttdev;”;
    1. include(‘adodb5/adodb.inc.php’);
  11. $db = ADONewConnection($dbdriver); # eg ‘mysql’ or ‘postgres’
  12. $db->debug = true;
  13. $db->charPage =65001;
  14. //$db->Connect($server, $user, $password, $database);
  15. $db->Connect($myDSN);
    1. //error:mssql server not support codes below
  16. //$db->Execute(“set names ‘utf8’”);
  17. echo “before query”;
  18. $rs = $db->Execute(‘select * from accounts’);
  19. print “<pre>”;
  20. print_r($rs->GetRows());
  21. print “</pre>”;
  22. ?>
  23. </body>
  24. </html>


如非注明转载, 均为原创. 本站遵循知识共享CC协议,转载请注明来源