PHP調用SQL Server存儲過程


一、安裝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,其它版本也懶得去測了。
下載地址:http://www.microsoft.com/downloads/details.aspx?familyid=CCDF728B-1EA0-48A8-A84A-5052214CAAD9&displaylang=en
下載后是個.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
下載地址:http://www.microsoft.com/downloads/details.aspx?displaylang=zh-cn&FamilyID=50b97994-8453-4998-8226-fa42ec403d17,找到對應項后根據自己機器情況(X86/X64)選擇下載。
    Microsoft SQL Server Native Client 2008支持SQL Server 2000、2005、2008
下載地址:http://www.microsoft.com/downloads/details.aspx?displaylang=zh-cn&FamilyID=c6c3e9ef-ba29-4a43-8d69-a2bed18fe73c,找到對應項后根據自己機器情況(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下載:http://adodb.sourceforge.net
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);

五、

<?php
require 'dbconn.php';
$userId = 1; // 定義輸入參數
$userName; // 定義返回值
$stmt = mssql_init("P__Test_GetData", $conn) or die("initialize stored procedure failure");
mssql_bind($stmt, "@userid", $userId, SQLINT4);
mssql_bind($stmt, "@username", $userName, SQLVARCHAR, true);
$rs = mssql_execute($stmt, false);
echo "This user name is: ".$userName;
?>


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM