PHP與SQL Server的連接是許多網(wǎng)站開(kāi)發(fā)者必須面對(duì)的挑戰(zhàn)。而PHP mssql擴(kuò)展是一種PHP內(nèi)置的支持與Microsoft SQL Server連接的工具。本文將探討如何使用PHP mssql擴(kuò)展建立穩(wěn)定的中間件來(lái)運(yùn)行SQL Server。
1. Mssql.dll擴(kuò)展
首先,我們需要檢查PHP環(huán)境是否支持Mssql.dll擴(kuò)展。在PHP 5.3之前的版本中,mssql.dll擴(kuò)展已經(jīng)包含在PHP Windows安裝包中,可以簡(jiǎn)單地啟用此擴(kuò)展從而開(kāi)始使用MSSQL數(shù)據(jù)庫(kù)。但隨著時(shí)間的推移,Mssql.dll 擴(kuò)展已經(jīng)逐漸被Microsoft官方放棄。現(xiàn)在,在PHP 7.x版本中,Mssql.dll擴(kuò)展已經(jīng)無(wú)法使用。因此,我們需要選擇其他合適的方法連接SQL Server數(shù)據(jù)庫(kù)。
2. SQLSRV擴(kuò)展
在PHP 5.3版本推出后,Microsoft公司推出了一個(gè)新的SQL Server驅(qū)動(dòng)程序—SQLSRV驅(qū)動(dòng),用來(lái)代替原有的Mssql.dll擴(kuò)展和ODBC驅(qū)動(dòng)。這個(gè)新的PHP SQL Server驅(qū)動(dòng)程序提供了對(duì)SQL Server 2005和更高版本的完全支持,并且在Windows和Unix操作系統(tǒng)中都可以使用。使用SQLSRV擴(kuò)展連接SQL Server的PHP代碼如下:
"my_database"); //數(shù)據(jù)庫(kù)名 $conn = sqlsrv_connect($serverName, $connInfo); if( $conn){ echo "Connection established.在該示例中,我們定義了服務(wù)器名和數(shù)據(jù)庫(kù)名,并通過(guò)sqlsrv_connect()函數(shù)與數(shù)據(jù)庫(kù)建立連接。如果連接成功,則輸出字符串“Connection established.”,否則輸出字符串“Connection failed.”,并輸出錯(cuò)誤信息。 3. PDO SQL Server驅(qū)動(dòng)程序 還有一種流行的連接SQL Server的PHP方法是使用PHP Data Objects(PDO)SQL Server驅(qū)動(dòng)程序。這種方法支持多個(gè)不同類型的數(shù)據(jù)庫(kù),包括MySQL和SQLite,但是需要安裝Microsoft SQL Server驅(qū)動(dòng)程序來(lái)支持SQL Server。PDO SQL Server驅(qū)動(dòng)程序使用dsn參數(shù)(數(shù)據(jù)來(lái)源名稱)來(lái)指定要連接的SQL Server名稱和數(shù)據(jù)庫(kù)名稱。以下是一個(gè)使用PDO SQL Server驅(qū)動(dòng)程序連接SQL Server的PHP代碼:
"; }else{ echo "Connection failed.
"; die( print_r(sqlsrv_errors(),true)); } ?>
$dbName ); $conn = new PDO( "sqlsrv:Server=$serverName;Database=$dbName", '', '', $connectionInfo); if( $conn ) { echo "Connection established.在該示例中,我們定義了服務(wù)器名和數(shù)據(jù)庫(kù)名,并使用PDO的構(gòu)造函數(shù)來(lái)建立連接。如果連接成功,則輸出字符串“Connection established.”,否則輸出字符串“Connection failed.”,并輸出錯(cuò)誤信息。 4. 結(jié)論 在本文中,我們討論了如何使用PHP擴(kuò)展來(lái)建立穩(wěn)定的中間件連接SQL Server數(shù)據(jù)庫(kù)。我們首先介紹了Mssql.dll擴(kuò)展的歷史和應(yīng)用,然后介紹了現(xiàn)代化的SQLSRV擴(kuò)展和PDO SQL Server驅(qū)動(dòng)程序的基本使用方法。使用這些工具,我們可以輕松連接并操作SQL Server數(shù)據(jù)庫(kù)。
"; }else{ echo "Connection failed.
"; die( print_r( $conn->errorInfo(), true)); } ?>