在配置php5時要使用mysql作為資料庫,很多人都認為只要在php.ini中添加extension=php_mysql.dll;指令即可,不清楚為什麼很多文章都推薦還要添加extension=php_mysqli.dll;指令。
只要查看官方最新php手冊便知,上面寫到:
下面是內建的擴充庫列表:
PHP 5 中(截止到 5.0.4)有以下修改。新增內建:DOM,LibXML,Iconv,SimpleXML,SPL 和SQLite。以下不再內建:MySQL 和 Overload。
原來php5沒有內建這些擴充庫(當然也可以得出在使用php4時,不需要添加這些指令),至於為什麼php5沒有不再綁定mysql的用戶端庫,手冊中也有說明:
部分原因是(無特定順序):
。現今大多數系統已經安裝了用戶端庫了。
。由於以上原因,保持多個版本的庫檔案會導致混亂。例如,如果把 mod_auth_mysql 串連到某個版本,但把 PHP 串連到了另一個版本,然後在 Apache 中同時啟用了它們,會得到無數錯誤。此外,綁定的庫檔案也不總是能和伺服器端的版本很好地配合。對此最明顯的癥狀是上哪裡去找 UNIX 域通訊端檔案 mysql.socket。
。維護有些鬆懈,並且已經越來越落後於發行的版本了。
。未來的庫版本是基於 GPL 的,因此我們沒有升級的途徑了,因為我們不能將基於 GPL 的庫和 BSD/Apache 風格許可證的項目綁定到一起。因此具有一個乾淨的 PHP 5 是最好的選擇。
配置時為php啟用兩個擴充庫的原因是因為:
。為了能使用基本函數操作訪問mysql資料庫伺服器,必須在配置php時添加mysql的支援,即使用php_mysql.dll擴充庫。
。雖然php_mysql.dll擴充庫相容mysql 4.1.0機器以後版本,但是它不支援這些版本提供的額外功能,要使用這些功能,還需要使用php_mysqli.dll擴充庫。
PHP 4 中(截止到 PHP 4.3.11):BCMath,Caledar,COM,Ctype,FTP,MySQL,ODBC,Overload,PCRE,Session,Tokenizer,WDDX,XML 和 Zlib。