這一部分對(duì)在PHP應(yīng)用開(kāi)發(fā)過(guò)程中需要和Mysql數(shù)據(jù)庫(kù)交互時(shí)可用的選擇進(jìn)行一個(gè)簡(jiǎn)單介紹。
什么是API?
一個(gè)應(yīng)用程序接口(Application Programming Interface的縮寫(xiě)),定義了類(lèi),方法,函數(shù),變量等等一切 你的應(yīng)用程序中為了完成特定任務(wù)而需要調(diào)用的內(nèi)容。在PHP應(yīng)用程序需要和數(shù)據(jù)庫(kù)進(jìn)行交互的時(shí)候所需要的API 通常是通過(guò)PHP擴(kuò)展暴露出來(lái)(給終端PHP程序員調(diào)用)。
API可以是面向過(guò)程的,也可以是面向?qū)ο蟮?。?duì)于面向過(guò)程的API,我們通過(guò)調(diào)用函數(shù)來(lái)完成任務(wù),而對(duì)于面向?qū)ο蟮腁PI, 我們實(shí)例化類(lèi),并在實(shí)例化后得到的對(duì)象上調(diào)用方法。對(duì)于這兩種接口而言,后者通常是首選的,因?yàn)樗蝇F(xiàn)代化,并且 給我們帶來(lái)了良好的代碼結(jié)構(gòu)。
當(dāng)構(gòu)建一個(gè)需要連接到MySQL服務(wù)端的PHP應(yīng)用的時(shí)候,有好幾種API可供選擇。此文檔就是討論這些可用的API并討論如何為 你的應(yīng)用選擇一個(gè)最佳的解決方案。
什么是連接器?
在MySQL文檔中,術(shù)語(yǔ)connector解釋為“一段允許你的應(yīng)用連接到MySQL數(shù)據(jù)庫(kù)服務(wù)器的軟件代碼”。 MySQL提供了很多語(yǔ)言的連接器,其中包括PHP的。
在你的PHP應(yīng)用需要和一個(gè)數(shù)據(jù)庫(kù)服務(wù)器交互的時(shí)候,你需要書(shū)寫(xiě)PHP代碼去完成“連接數(shù)據(jù)庫(kù)服務(wù)器”,“查詢(xún)數(shù)據(jù)庫(kù)“以及其他數(shù)據(jù)庫(kù)相關(guān)功能 等一系列活動(dòng)。你的PHP應(yīng)用將會(huì)使用提供這些API的軟件,或者在需要的時(shí)候使用一些中間庫(kù),來(lái)處理你的應(yīng)用和數(shù)據(jù)庫(kù)服務(wù)器之間的交互。 這種軟件通常被認(rèn)為是連接器,它允許你的引用連接到數(shù)據(jù)庫(kù)服務(wù)器。
什么是驅(qū)動(dòng)?
驅(qū)動(dòng)是一段設(shè)計(jì)用來(lái)于一種特定類(lèi)型的數(shù)據(jù)庫(kù)服務(wù)器進(jìn)行交互的軟件代碼。驅(qū)動(dòng)可能會(huì)調(diào)用一些庫(kù),比如MySQL客戶(hù)端庫(kù)或者M(jìn)ySQL Native驅(qū)動(dòng)庫(kù)。 這些庫(kù)實(shí)現(xiàn)了用于和MySQL數(shù)據(jù)庫(kù)服務(wù)器進(jìn)行交互的底層協(xié)議。
通過(guò)一個(gè)例子PDO(PHP Database Object的縮寫(xiě))數(shù)據(jù)庫(kù)抽象層可以 使用多種特定數(shù)據(jù)庫(kù)的驅(qū)動(dòng)。其中一種驅(qū)動(dòng)就是PDO MYSQL驅(qū)動(dòng),它就是與MySQL服務(wù)器之間的接口。
有時(shí)大家會(huì)不加區(qū)分的使用連接器和驅(qū)動(dòng)這兩個(gè)術(shù)語(yǔ)。在MySQL相關(guān)文檔中driver
術(shù)語(yǔ)被作為一個(gè)連接器包
中提供特定數(shù)據(jù)庫(kù)部分的軟件代碼。
什么是擴(kuò)展?
在PHP文檔中你還會(huì)發(fā)現(xiàn)很多其他的擴(kuò)展。PHP代碼是由一個(gè)核心,一些可選擴(kuò)展組成了核心功能。PHP
的MySQL相關(guān)擴(kuò)展,比如mysqli
,mysql
都是基于PHP擴(kuò)展框架實(shí)現(xiàn)的。
擴(kuò)展一個(gè)典型的作用就是暴露一個(gè)API給PHP程序員,允許擴(kuò)展自己的功能可以被程序員使用。當(dāng)然,也有一部分基于PHP擴(kuò)展框架 開(kāi)發(fā)的擴(kuò)展不會(huì)給PHP程序員暴露API接口。
比如說(shuō)PDO MySQL驅(qū)動(dòng)擴(kuò)展,就沒(méi)有向PHP程序員暴露API接口,但是向它上層的PDO層提供了一個(gè)接口。
術(shù)語(yǔ)API和擴(kuò)展描述的不是同一類(lèi)事物,因?yàn)閿U(kuò)展可能并不需要暴露一個(gè)API接口給程序員。
PHP中提供的用于MySQL的主要API是什么?
當(dāng)考慮連接到MySQL數(shù)據(jù)庫(kù)服務(wù)器的時(shí)候,有三種主要的API可供選擇:
PHP的MySQL擴(kuò)展
PHP的mysqli擴(kuò)展
PHP數(shù)據(jù)對(duì)象(PDO)
三者都有各自的優(yōu)缺點(diǎn)。下面的討論就是為了對(duì)每種API的關(guān)鍵方面給出一個(gè)簡(jiǎn)短的介紹。
什么是PHP的MySQL擴(kuò)展?
這是設(shè)計(jì)開(kāi)發(fā)允許PHP應(yīng)用與MySQL數(shù)據(jù)庫(kù)交互的早期擴(kuò)展。mysql
擴(kuò)展提供了一個(gè)面向過(guò)程
的接口,并且是針對(duì)MySQL4.1.3或更早版本設(shè)計(jì)的。因此,這個(gè)擴(kuò)展雖然可以與MySQL4.1.3或更新的數(shù)據(jù)庫(kù)服務(wù)端
進(jìn)行交互,但并不支持后期MySQL服務(wù)端提供的一些特性。
注意:
如果你是使用MySQL4.1.3或更新的服務(wù)端版本,強(qiáng)烈建議你使用
mysqli
擴(kuò)展替代它。
mysql
擴(kuò)展的源代碼在PHP擴(kuò)展目錄ext/mysql下。
對(duì)于mysql
擴(kuò)展的更多信息,請(qǐng)參閱Mysql(原始)。
什么是PHP的mysqli擴(kuò)展?
mysqli
擴(kuò)展,我們有時(shí)稱(chēng)之為MySQL增強(qiáng)擴(kuò)展,可以用于使用
MySQL4.1.3或更新版本中新的高級(jí)特性。mysqli
擴(kuò)展在PHP 5及以后版本中包含。
mysqli
擴(kuò)展有一系列的優(yōu)勢(shì),相對(duì)于mysql
擴(kuò)展的提升主要有:
面向?qū)ο蠼涌?
prepared語(yǔ)句支持(譯注:關(guān)于prepare請(qǐng)參閱mysql相關(guān)文檔)
多語(yǔ)句執(zhí)行支持
事務(wù)支持
增強(qiáng)的調(diào)試能力
嵌入式服務(wù)支持
注意:
如果你使用MySQL4.1.3或更新版本,強(qiáng)烈建議你使用這個(gè)擴(kuò)展。
在提供了面向?qū)ο蠼涌诘耐瑫r(shí)也提供了一個(gè)面向過(guò)程的接口。
mysqli
擴(kuò)展是使用PHP擴(kuò)展框架構(gòu)建的,它的源代碼在PHP源碼目錄下的ext/mysqli中。
對(duì)于mysqli
擴(kuò)展的更多信息,請(qǐng)參閱Mysqli。
什么是PDO?
PHP數(shù)據(jù)對(duì)象,是PHP應(yīng)用中的一個(gè)數(shù)據(jù)庫(kù)抽象層規(guī)范。PDO提供了一個(gè)統(tǒng)一的API接口可以使得你的PHP應(yīng)用不去關(guān)心具體要 連接的數(shù)據(jù)庫(kù)服務(wù)器系統(tǒng)類(lèi)型。也就是說(shuō),如果你使用PDO的API,可以在任何需要的時(shí)候無(wú)縫切換數(shù)據(jù)庫(kù)服務(wù)器,比如從Firebird 到MySQL,僅僅需要修改很少的PHP代碼。
其他數(shù)據(jù)庫(kù)抽象層的例子包括Java應(yīng)用中的JDBC以及Perl中的DBI。
當(dāng)然,PDO也有它自己的先進(jìn)性,比如一個(gè)干凈的,簡(jiǎn)單的,可移植的API,它最主要的缺點(diǎn)是會(huì)限制讓你不能使用 后期MySQL服務(wù)端提供所有的數(shù)據(jù)庫(kù)高級(jí)特性。比如,PDO不允許使用MySQL支持的多語(yǔ)句執(zhí)行。
PDO是基于PHP擴(kuò)展框架實(shí)現(xiàn)的,它的源碼在PHP源碼目錄的ext/pdo下。
PDO的更多信息,請(qǐng)參閱PDO。
什么是PDO的MySQL驅(qū)動(dòng)器?
PDO的MySQL驅(qū)動(dòng)并不是一套API,至少?gòu)腜HP程序員的角度來(lái)看是這樣的。實(shí)際上,PDO的MySQL驅(qū)動(dòng)處于PDO自己的下層, 提供了特定的Mysql功能。程序員直接調(diào)用PDO的API,而PDO使用了PDO的MySQL驅(qū)動(dòng)完成與MySQL服務(wù)器端的交互。
PDO的MySQL驅(qū)動(dòng)是眾多PDO驅(qū)動(dòng)中的一個(gè)。其他可用的PDO驅(qū)動(dòng)包括Firebird,PostgreSQL等等。
PDO的MySQL驅(qū)動(dòng)是基于PHP擴(kuò)展框架實(shí)現(xiàn)的。它的源碼在PHP源碼目錄下的ext/pdo_mysql。 它沒(méi)有向PHP程序員暴露API。
PDO的MySQL擴(kuò)展的更多信息請(qǐng)參閱MySQL (PDO)。
什么是PHP的MySQL Native 驅(qū)動(dòng)?
為了與MySQL數(shù)據(jù)庫(kù)服務(wù)端進(jìn)行交互,mysql
擴(kuò)展,mysqli
擴(kuò)展,
PDO MySQL驅(qū)動(dòng)都使用了實(shí)現(xiàn)了必要的協(xié)議的底層庫(kù)。以前,可用的庫(kù)只有MySQL客戶(hù)端庫(kù)和libmysql
。
然而,libmysql
包含的接口沒(méi)有針對(duì)與PHP的應(yīng)用交互進(jìn)行優(yōu)化,libmysql
是早期為C應(yīng)用程序設(shè)計(jì)的?;谶@個(gè)原因,MySQL Native驅(qū)動(dòng)mysqlnd
,作為libmysql
的一個(gè)
針對(duì)PHP應(yīng)用的修改版本被開(kāi)發(fā)。
mysql
,mysqli
以及PDO Mysql驅(qū)動(dòng)都可以各自配置使用
libmysql
或者mysqlnd
。mysqlnd
作為一個(gè)專(zhuān)門(mén)設(shè)計(jì)
用于PHP系統(tǒng)的庫(kù),它在內(nèi)存和速度上都比libmysql
有很大提升。非常希望你去嘗試這些提升。
注意:
MySQL Native驅(qū)動(dòng)僅僅可以在MySQL服務(wù)端版本為4.1.3及以后版本才可以使用。
MySQL Native驅(qū)動(dòng)是基于PHP擴(kuò)展框架實(shí)現(xiàn)的。源代碼位于PHP源碼目錄的ext/mysqlnd下。 它沒(méi)有向PHP程序員暴露接口。
特性比較
下表比較了PHP中三種主要的MySQL連接方式的功能:
PHP的mysqli擴(kuò)展 | PDO (使用PDO MySQL驅(qū)動(dòng)和MySQL Native驅(qū)動(dòng)) | PHP的mysql擴(kuò)展 | |
---|---|---|---|
引入的PHP版本 | 5.0 | 5.0 | 3.0之前 |
PHP5.x是否包含 | 是 | 是 | 是 |
MySQL開(kāi)發(fā)狀態(tài) | 活躍 | 在PHP5.3中活躍 | 僅維護(hù) |
在MySQL新項(xiàng)目中的建議使用程度 | 建議 - 首選 | 建議 | 不建議 |
API的字符集支持 | 是 | 是 | 否 |
服務(wù)端prepare語(yǔ)句的支持情況 | 是 | 是 | 否 |
客戶(hù)端prepare語(yǔ)句的支持情況 | 否 | 是 | 否 |
存儲(chǔ)過(guò)程支持情況 | 是 | 是 | 否 |
多語(yǔ)句執(zhí)行支持情況 | 是 | 大多數(shù) | 否 |
是否支持所有MySQL4.1以上功能 | 是 | 大多數(shù) | 否 |