php adodb连接mssql解决乱码问题
程序员文章站
2023-11-18 18:57:34
周海汉/文ado可以用 new com("adodb.connection", null, cp_utf8)//65001 这样的语句来实现正确转换。但ado对php的支持...
周海汉/文
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]
但没解决设置数据库名字的地方。
痛苦了很久,只能找到如下的办法解决:
<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>
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]
但没解决设置数据库名字的地方。
痛苦了很久,只能找到如下的办法解决:
复制代码 代码如下:
<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>
推荐阅读
-
php adodb连接mssql解决乱码问题
-
解决php接收shell返回的结果中文乱码问题
-
PHP json_encode中文乱码问题的解决办法
-
Python连接mssql数据库编码问题解决方法
-
PHP substr 截取字符串出现乱码问题解决方法[utf8与gb2312]
-
解决MSSQL2005远程连接sql2000非默认端口数据库的问题
-
PHP连接MySQL查询结果中文显示乱码解决方法
-
php中json_encode处理gbk与gb2312中文乱码问题的解决方法
-
Windows下利用Gvim写PHP产生中文乱码问题解决方法
-
PHP中使用file_get_contents抓取网页中文乱码问题解决方法