php drive mssql,PHP 连接 MSSQL 2005/2008 以UTF8存取 并让ADODB支持的安装设置
時間:2009-11-9 11:14
作者:欣然隨風
因系統大量使用AJAX,為避免編碼轉來轉去的麻煩,把文件都設為了UTF8。但在操作MSSQL時遇到亂碼問題,查閱一番后原來是MSSQL不支持UTF8,寒~~ 花了一天時間來處理這個問題,并最終解決:
一、安裝SQL Server Driver for PHP
在微軟官網上發現了這個東西,他提供了一套PHP對MS2005/2008操作的全新函數庫,并且支持UTF8,作為PHP的擴展運行。看來MS對PHP還比較親善,PHP自帶的mssql操作函數對MS2005/2008的一些新功能不支持,MS就自己提供了解決方法,贊一個!不過只支持PHP5.2/5.3,MS說目前在PHP 5.2上測試過,低版本的是否支持就不清楚了。我的系統正好也用的是PHP5.2,其它版本也懶得去測了。
下載地址:
下載后是個.exe的壓縮包,解開后有下列.dll文件:
php_sqlsrv_52_nts_vc6.dll
php_sqlsrv_52_ts_vc6.dll
php_sqlsrv_53_nts_vc6.dll
php_sqlsrv_53_nts_vc9.dll
php_sqlsrv_53_ts_vc6.dll
php_sqlsrv_53_ts_vc9.dll
要根據自己的PHP環境選擇一個合適的.dll,壓縮包的說明文檔給出了適用范圍:
Driver file
PHP version
Thread safe?
Use with PHP .dll
php_sqlsrv_53_nts_vc6.dll
5.3
no
php5.dll
php_sqlsrv_53_nts_vc9.dll
5.3
no
php5.dll
php_sqlsrv_53_ts_vc6.dll
5.3
yes
php5ts.dll
php_sqlsrv_53_ts_vc9.dll
5.3
yes
php5ts.dll
php_sqlsrv_52_nts_vc6.dll
5.2
no
php5.dll
php_sqlsrv_52_ts_vc6.dll
5.2
yes
php5ts.dll
DLL名字稱中的_vc6/_vc9表示你使用的PHP為vc6或vc9編譯,PHP version中確定適用版本,Thread safe為該版本安全性,Use with PHP .dll是你PHP的安裝方式。更多說明請參考文檔。
我這里選擇的是php_sqlsrv_52_ts_vc6.dll,拷貝到php/ext/下,然后在php.ini中添加一行“extension=php_sqlsrv_52_ts_vc6.dll”,重啟WEB服務。phpinfo();查看一下,如果有“sqlsrv”擴展項,就表示安裝成功了。
二、安裝Microsoft SQL Server Native Client
這個是MSSQL的客戶端存取程序,它提供了ODBC、OLE DB、ADO 等方式連接 MSSQL。 如果已經安裝了MSSQL2005/2008,則已經安裝了對應版本的此程序,不用單獨安裝了。
Microsoft SQL Server Native Client 2005支持SQL Server 7、2000、2005
下載地址:,找到對應項后根據自己機器情況(X86/X64)選擇下載。
Microsoft SQL Server Native Client 2008支持SQL Server 2000、2005、2008
下載地址:,找到對應項后根據自己機器情況(X86/X64/IA64)選擇下載。
三、至此已經可以使用UTF8進行存取了
新建一個UTF8編碼的文件,測試一下:
$connstr = array("Database"=>"test","Uid"=>"sa","Pwd"=>"xxx","CharacterSet" => "UTF-8");
$conn = sqlsrv_connect('127.0.0.1',$connstr);
if($conn==false) print_r(sqlsrv_errors(),true);
$sql = "SELECT TOP 10 * FROM table";
if($data = sqlsrv_query($conn, $sql))
{
while($row = sqlsrv_fetch_array($data,SQLSRV_FETCH_ASSOC))
{
print_r($row);
}
}
sqlsrv_close($conn);
四、ADODB支持
看到上例可能要抓狂了,因為提供了全新的一套操作函數,使用起來不習慣,跟現有系統也不兼容。去下載了個最新版的ADODB后驚喜的發現它已經封裝了該系列函數,幫我們解決了此問題。只需作個簡單的修改:
找到/adodb/drivers/adodb-mssqlnative.inc.php,在_connect方法后有一行:
“ $connectionInfo = array("Database"=>$argDatabasename,'UID'=>$argUsername,'PWD'=>$argPassword);”
改為:
“ $connectionInfo = array("Database"=>$argDatabasename,'UID'=>$argUsername,'PWD'=>$argPassword,"CharacterSet" => 'UTF-8');”
ADODB下載:
OK了,測試代碼:
$conn = ADONewConnection('mssqlnative');
$conn->Connect(DB_HOST,DB_USER,DB_PASS,DB_NAME);
$ADODB_FETCH_MODE= ADODB_FETCH_ASSOC;
$sql = "SELECT * FROM table";
$data = $conn->GetAll($sql);
print_r($data);
爽了!
五、AD一下
總結
以上是生活随笔為你收集整理的php drive mssql,PHP 连接 MSSQL 2005/2008 以UTF8存取 并让ADODB支持的安装设置的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: php源代码压缩,PHP_PHP 源代码
- 下一篇: 口令红包 java,[1.7.2]Gif