首頁 > 後端開發 > PHP7 > php7如何使用PDO連接資料庫

php7如何使用PDO連接資料庫

醉折花枝作酒筹
發布: 2023-02-18 06:56:02
轉載
2402 人瀏覽過

在php中,可以使用pdo連接資料庫,但不一定每個人都知道同時兼容windows和centos的方法,下面就來介紹一下使用PDO連接,同時兼容windows和centos的方法,有需要的可以看看。

php7如何使用PDO連接資料庫

一、首先是windows安裝擴充功能

7.0.x的擴充下載位址:

Microsoft Drivers for PHP for SQL Server  https ://www.microsoft.com/en-us/download/details.aspx?id=20098

ODBC Driver:

Microsoft® ODBC Driver 11 for SQL Server® - Windows (支持Sql Server® 2005)  https://www.microsoft.com/zh-CN/download/details.aspx?id=36434

Microsoft® ODBC Driver 13 for SQL Server® - Windows Linux (支援最新的SQL Server® 2016)  https://www.microsoft.com/zh-CN/download/details.aspx?id=50420

安裝設定:

#下載SQL Server的PHP擴充( Microsoft Drivers for PHP for SQL Server),連線裡有多個文件,只需下載SQLSRV40.EXE 即可。

解壓縮後根據自己PHP的版本選擇32位元或64位元的擴展,注意區分(Thread safe?)nts和ts。

複製擴充功能需要的檔案到PHP擴充目錄。 (例如我在這裡使用的是:php_pdo_sqlsrv_7_ts_x64.dll 和 php_sqlsrv_7_ts_x64.dll)

修改php.ini新增以下兩行來啟用擴充:

extension=php_sqlsrv_7_ts_x64.dll
extension=php_pdo_sqlsrv_7_ts_x64.dll
登入後複製

安裝ODBC Driver,依照自己的需求選擇上面的地址下載並安裝。

現在可以使用phpinfo()來查看是否成功載入了 pdo_sqlsrv 模組。

二、Centos安裝擴充功能

前提貌似文件說一定要PHP7以後的版本,以前很多都是第三方FreeTDS,再怎麼搞也沒有微軟官方的穩定吧!

1、加入微軟的來源

curl https://packages.microsoft.com/config/rhel/7/prod.repo > /etc/yum.repos.d/mssqlrelease.repo
登入後複製

2、防止衝突先卸載原始版本(可選)

yum remove unixODBC
登入後複製

3、安裝驅動程式(三個都要安裝上,缺一不可)

yum install msodbcsql mssql-tools unixODBC-devel
登入後複製

4、下載pdo_sqlsrv擴充包 

http://pecl.php.net/package/pdo_sqlsrv
登入後複製

5、以4.3.8為例

tar -zxvf pdo_sqlsrv-4.3.8.tgz
登入後複製

6、進入解壓縮目錄

cd pdo_sqlsrv-4.0.8
登入後複製

7、執行PHP的一個擴充指令

/usr/local/php/bin/phpize
登入後複製

8、編譯

./configure --with-php-config=/usr/local/php/bin/php-config
登入後複製

9、安裝

make && make install
登入後複製

10、修改/usr/local/php/etc/php .ini 加extension

extension = "pdo_sqlsrv.so"
登入後複製

11、重啟php-fpm和nginx,大功告成 

下面我重點說我的踩坑記錄:

windows安裝完後,2種方式調用,我最開始用的sqlsrv_connect方式,能成功調用,具體的api參考這裡。

https://docs.microsoft.com/en-us/sql/connect/php/sqlsrv-driver-api-reference
登入後複製

但上面的安裝方法,Centos伺服器最終是只安裝pdo_sqlsrv.so的。所以只能採用另外一種pdo方式調用,才是通用的。

https://github.com/Microsoft/msphpsql/edit/master/sample/pdo_sqlsrv_sample.php
登入後複製
<?php
    echo "\n";
    $serverName = "tcp:yourserver.database.windows.net,1433";
	$database = "yourdatabase";
	$uid = "yourusername";
	$pwd = "yourpassword";
	
	 //Establishes the connection
	 $conn = new PDO( "sqlsrv:server=$serverName ; Database = $database", $uid, $pwd);
	 
	 //Select Query
	 $tsql = "SELECT [CompanyName] FROM SalesLT.Customer";
	 
	 //Executes the query
	 $getProducts = $conn->query( $tsql );
	 
	 //Error handling
	 FormatErrors ($conn->errorInfo());
	 
	 $productCount = 0;
	 $ctr = 0;
	 ?> 
	 
	 <h1> First 10 results are : </h1>
	 
	 <?php
	 while($row = $getProducts->fetch(PDO::FETCH_ASSOC))
	 {
		 if($ctr>9)
			 break; 
		 $ctr++;
		 echo($row[&#39;CompanyName&#39;]);
		 echo("<br/>");
		 $productCount++;
	 }
	 $getProducts = NULL;
	 
	 $tsql = "INSERT INTO SalesLT.Product (Name, ProductNumber, StandardCost, ListPrice, SellStartDate) OUTPUT INSERTED.* VALUES (&#39;SQL New 1&#39;, &#39;SQL New 2&#39;, 0, 0, getdate())";
	 
	 //Insert query
	 $insertReview = $conn->query( $tsql );
	 FormatErrors ($conn->errorInfo());
	 ?> 
	 
	 <h1> Product Key inserted is :</h1> 
	 
	 <?php
	 while($row = $insertReview->fetch(PDO::FETCH_ASSOC))
	 {
		 echo($row[&#39;ProductID&#39;]."<br/>");
	 }
	 $insertReview = NULL;
	 
	 //Delete Query
	 //We are deleting the same record
	 $tsql = "DELETE FROM [SalesLT].[Product] WHERE Name=?";
	 $param = "SQL New 1";
	 
	 $deleteReview = $conn->prepare($tsql);
	 $deleteReview->bindParam(1, $param);
	 
	 $deleteReview->execute();
	 FormatErrors ($deleteReview->errorInfo());
	 
	 function FormatErrors( $error )
	 {
	    /* Display error. */
	    echo "Error information: <br/>";
	 
	    echo "SQLSTATE: ".$error[0]."<br/>";
	    echo "Code: ".$error[1]."<br/>";
	    echo "Message: ".$error[2]."<br/>";
	 }
?>
登入後複製

推薦學習:php影片教學

以上是php7如何使用PDO連接資料庫的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:csdn.net
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板