在配置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。