php adodb 读取中文乱码,php adodb连接mssql解决乱码问题

php adodb连接mssql解决乱码问题

2021-01-23 18:42:2416

周海汉/文

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:cvttdev@172.16.22.40/sqloledb?charpage=65001';

其格式是'driver://user:passwd@host/database?options[=value]

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

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

复制代码 代码如下:

$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 "

";

print_r($rs->GetRows());

print "

";

?>

点击这里复制本文地址

以上内容由聚米学院网友整理呈现,如对侵犯您的权益,请联系邮箱:fzsbm@qq.com

56bfa8a8882ed32676e72bee4f02ae3a.png

支持Ctrl+Enter提交

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值