周海漢/文
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 For all drivers
'persist', 'persistent', 'debug', 'fetchmode', 'new'
Interbase/Firebird
'dialect','charsetset','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_dbword ';
$database='sqloledb';
//$dbdriver='ado://sa:cvttdev@172.16.22.40/sqloledb?charpage=65001';
$myDSN="PROVIDER=MSDASQLSQL ;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 "
"; <br>print_r($rs->GetRows()); <br>print "
";
?>
以上就介紹了mysql workbench php adodb連接mssql解決亂碼問題,包含了mysql workbench方面的內容,希望對PHP教學有興趣的朋友有幫助。