php adodb連接mssql解決亂碼問題
更新時間:2009年06月12日 19:17:08 作者:
php程序是utf-8的,sqlserver是2005中文,內(nèi)碼是gb18030. 普通的mssql_connect無法設(shè)置內(nèi)碼轉(zhuǎn)換,讀出來的數(shù)據(jù)在utf-8頁面顯示亂碼。
周海漢/文
ADO可以用 new COM("ADODB.Connection", NULL, CP_UTF8)//65001 這樣的語句來實現(xiàn)正確轉(zhuǎn)換。但ADO對php的支持缺乏文檔。而有個開源的adodb,文檔較為豐富。
其中對不同數(shù)據(jù)庫驅(qū)動,設(shè)置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這個屬性來設(shè)置uft-8,類似new COM的方式。但發(fā)現(xiàn)當將AdoNewConnection($dbdriver)的$dbdriver設(shè)為'ado'或'ado_mssql'時,其傳進去的database被替換為provider。那database的名字如何設(shè)置呢?一直沒找到辦法。
$dbdriver='ado://sa:cvttdev@172.16.22.40/sqloledb?charpage=65001';
其格式是'driver://user:passwd@host/database?options[=value]
但沒解決設(shè)置數(shù)據(jù)庫名字的地方。
痛苦了很久,只能找到如下的辦法解決:
<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 這樣的語句來實現(xiàn)正確轉(zhuǎn)換。但ADO對php的支持缺乏文檔。而有個開源的adodb,文檔較為豐富。
其中對不同數(shù)據(jù)庫驅(qū)動,設(shè)置UTF-8的方法還不一樣,如下:
復(fù)制代碼 代碼如下:
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這個屬性來設(shè)置uft-8,類似new COM的方式。但發(fā)現(xiàn)當將AdoNewConnection($dbdriver)的$dbdriver設(shè)為'ado'或'ado_mssql'時,其傳進去的database被替換為provider。那database的名字如何設(shè)置呢?一直沒找到辦法。
$dbdriver='ado://sa:cvttdev@172.16.22.40/sqloledb?charpage=65001';
其格式是'driver://user:passwd@host/database?options[=value]
但沒解決設(shè)置數(shù)據(jù)庫名字的地方。
痛苦了很久,只能找到如下的辦法解決:
復(fù)制代碼 代碼如下:
<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>
相關(guān)文章
windows下的WAMP環(huán)境搭建圖文教程(推薦)
下面小編就為大家?guī)硪黄獁indows下的WAMP環(huán)境搭建圖文教程(推薦)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-07-07
實例講解通過PHP創(chuàng)建數(shù)據(jù)庫
在本篇文章里小編給大家分享了關(guān)于如何通過​PHP創(chuàng)建數(shù)據(jù)庫的知識點內(nèi)容,有需要的朋友們學習下。2019-01-01
asp和php下textarea提交大量數(shù)據(jù)發(fā)生丟失的解決方法
2008-01-01
php+jQuery+Ajax實現(xiàn)點贊效果的方法(附源碼下載)
這篇文章主要介紹了php+jQuery+Ajax實現(xiàn)點贊效果的方法,結(jié)合實例形式詳細介紹了php結(jié)合jQuery的ajax無刷新提交實現(xiàn)點贊功能的具體步驟與相關(guān)技巧,需要的朋友可以參考下2015-12-12

