mysqli、pdo_mysql和mysql之間的區別以及選擇
這裡對在PHP應用開發過程中需要和Mysql資料庫互動時可用的選擇進行一個簡單介紹。
什麼是API?
一個應用程式介面(Application Programming Interface的縮寫),定義了類,方法,函式,變數等等一切 你的應用程式中為了完成特定任務而需要呼叫的內容。在PHP應用程式需要和資料庫進行互動的時候所需要的API 通常是通過PHP擴充套件暴露出來(給終端PHP程式設計師呼叫)。
API可以是面向過程的,也可以是面向物件的。對於面向過程的API,我們通過呼叫函式來完成任務,而對於面向物件的API, 我們例項化類,並在例項化後得到的物件上呼叫方法。對於這兩種介面而言,後者通常是首選的,因為它更加現代化,並且 給我們帶來了良好的程式碼結構。
當構建一個需要連線到MySQL服務端的PHP應用的時候,有好幾種API可供選擇。此文件就是討論這些可用的API並討論如何為 你的應用選擇一個最佳的解決方案。
什麼是聯結器?
在MySQL文件中,術語connector解釋為“一段允許你的應用連線到MySQL資料庫伺服器的軟體程式碼”。 MySQL提供了很多語言的聯結器,其中包括PHP的。
在你的PHP應用需要和一個數據庫伺服器互動的時候,你需要書寫PHP程式碼去完成“連線資料庫伺服器”,“查詢資料庫“以及其他資料庫相關功能 等一系列活動。你的PHP應用將會使用提供這些API的軟體,或者在需要的時候使用一些中間庫,來處理你的應用和資料庫伺服器之間的互動。 這種軟體通常被認為是聯結器,它允許你的引用連線
什麼是驅動?
驅動是一段設計用來於一種特定型別的資料庫伺服器進行互動的軟體程式碼。驅動可能會呼叫一些庫,比如MySQL客戶端庫或者MySQL Native驅動庫。 這些庫實現了用於和MySQL資料庫伺服器進行互動的底層協議。
通過一個例子PDO(PHP Database Object的縮寫)資料庫抽象層可以 使用多種特定資料庫的驅動。其中一種驅動就是PDO MYSQL驅動,它就是與MySQL伺服器之間的介面。
有時大家會不加區分的使用聯結器和驅動這兩個術語。在MySQL相關文件中"driver"術語被作為一個聯結器包 中提供特定資料庫部分的軟體程式碼。
什麼是擴充套件?
在PHP文件中你還會發現很多其他的擴充套件。PHP程式碼是由一個核心,一些可選擴充套件組成了核心功能。PHP 的MySQL相關擴充套件,比如mysqli,mysql都是基於PHP擴充套件框架實現的。
擴充套件一個典型的作用就是暴露一個API給PHP程式設計師,允許擴充套件自己的功能可以被程式設計師使用。當然,也有一部分基於PHP擴充套件框架 開發的擴充套件不會給PHP程式設計師暴露API介面。
比如說PDO MySQL驅動擴充套件,就沒有向PHP程式設計師暴露API介面,但是向它上層的PDO層提供了一個介面。
術語API和擴充套件描述的不是同一類事物,因為擴充套件可能並不需要暴露一個API介面給程式設計師。
PHP中提供的用於MySQL的主要API是什麼?
當考慮連線到MySQL資料庫伺服器的時候,有三種主要的API可供選擇:
-
PHP的MySQL擴充套件
-
PHP的mysqli擴充套件
-
PHP資料物件(PDO)
三者都有各自的優缺點。下面的討論就是為了對每種API的關鍵方面給出一個簡短的介紹。
什麼是PHP的MySQL擴充套件?
這是設計開發允許PHP應用與MySQL資料庫互動的早期擴充套件。mysql擴充套件提供了一個面向過程 的介面,並且是針對MySQL4.1.3或更早版本設計的。因此,這個擴充套件雖然可以與MySQL4.1.3或更新的資料庫服務端 進行互動,但並不支援後期MySQL服務端提供的一些特性。
mysql擴充套件的原始碼在PHP擴充套件目錄ext/mysql下。
對於mysql擴充套件的更多資訊,請參閱Mysql(原始)。
什麼是PHP的mysqli擴充套件?
mysqli擴充套件,我們有時稱之為MySQL增強擴充套件,可以用於使用 MySQL4.1.3或更新版本中新的高階特性。mysqli擴充套件在PHP 5及以後版本中包含。
mysqli擴充套件有一系列的優勢,相對於mysql擴充套件的提升主要有:
-
面向物件介面
-
prepared語句支援(譯註:關於prepare請參閱mysql相關文件)
-
多語句執行支援
-
事務支援
-
增強的除錯能力
-
嵌入式服務支援
在提供了面向物件介面的同時也提供了一個面向過程的介面。
mysqli擴充套件是使用PHP擴充套件框架構建的,它的原始碼在PHP原始碼目錄下的ext/mysqli中。
對於mysqli擴充套件的更多資訊,請參閱Mysqli。
什麼是PDO?
PHP資料物件,是PHP應用中的一個數據庫抽象層規範。PDO提供了一個統一的API介面可以使得你的PHP應用不去關心具體要 連線的資料庫伺服器系統型別。也就是說,如果你使用PDO的API,可以在任何需要的時候無縫切換資料庫伺服器,比如從Firebird 到MySQL,僅僅需要修改很少的PHP程式碼。
其他資料庫抽象層的例子包括Java應用中的JDBC以及Perl中的DBI。
當然,PDO也有它自己的先進性,比如一個乾淨的,簡單的,可移植的API,它最主要的缺點是會限制讓你不能使用 後期MySQL服務端提供所有的資料庫高階特性。比如,PDO不允許使用MySQL支援的多語句執行。
PDO是基於PHP擴充套件框架實現的,它的原始碼在PHP原始碼目錄的ext/pdo下。
PDO的更多資訊,請參閱PDO。
什麼是PDO的MySQL驅動器?
PDO的MySQL驅動並不是一套API,至少從PHP程式設計師的角度來看是這樣的。實際上,PDO的MySQL驅動處於PDO自己的下層, 提供了特定的Mysql功能。程式設計師直接呼叫PDO的API,而PDO使用了PDO的MySQL驅動完成與MySQL伺服器端的互動。
PDO的MySQL驅動是眾多PDO驅動中的一個。其他可用的PDO驅動包括Firebird,PostgreSQL等等。
PDO的MySQL驅動是基於PHP擴充套件框架實現的。它的原始碼在PHP原始碼目錄下的ext/pdo_mysql。 它沒有向PHP程式設計師暴露API。
PDO的MySQL擴充套件的更多資訊請參閱MySQL (PDO)。
什麼是PHP的MySQL Native 驅動?
為了與MySQL資料庫服務端進行互動,mysql擴充套件,mysqli擴充套件, PDO MySQL驅動都使用了實現了必要的協議的底層庫。以前,可用的庫只有MySQL客戶端庫和libmysql。
然而,libmysql包含的介面沒有針對與PHP的應用互動進行優化,libmysql 是早期為C應用程式設計的。基於這個原因,MySQL Native驅動mysqlnd,作為libmysql的一個 針對PHP應用的修改版本被開發。
mysql,mysqli以及PDO Mysql驅動都可以各自配置使用 libmysql或者mysqlnd。mysqlnd作為一個專門設計 用於PHP系統的庫,它在記憶體和速度上都比libmysql有很大提升。非常希望你去嘗試這些提升。
MySQL Native驅動是基於PHP擴充套件框架實現的。原始碼位於PHP原始碼目錄的ext/mysqlnd下。 它沒有向PHP程式設計師暴露介面。
特性比較
下表比較了PHP中三種主要的MySQL連線方式的功能:
PHP的mysqli擴充套件 | PDO (使用PDO MySQL驅動和MySQL Native驅動) | PHP的mysql擴充套件 | |
---|---|---|---|
引入的PHP版本 | 5.0 | 5.0 | 3.0之前 |
PHP5.x是否包含 | 是 | 是 | 是 |
MySQL開發狀態 | 活躍 | 在PHP5.3中活躍 | 僅維護 |
在MySQL新專案中的建議使用程度 | 建議 - 首選 | 建議 | 不建議 |
API的字符集支援 | 是 | 是 | 否 |
服務端prepare語句的支援情況 | 是 | 是 | 否 |
客戶端prepare語句的支援情況 | 否 | 是 | 否 |
儲存過程支援情況 | 是 | 是 | 否 |
多語句執行支援情況 | 是 | 大多數 | 否 |
是否支援所有MySQL4.1以上功能 | 是 | 大多數 | 否 |
簡單來說就是 : mysqli(首選) pdo_mysql(建議) mysql(不建議)
原文連結 http://php.net/manual/zh/mysqli.overview.php