PHP數(shù)據(jù)庫抽象層之PDO(二)——連接與連接管理
連接是通過創(chuàng)建 PDO 基類的實例而建立的。不管使用哪種驅(qū)動程序,都是用 PDO 類名。構(gòu)造函數(shù)接收用于指定數(shù)據(jù)庫源(所謂的 DSN)以及可能還包括用戶名和密碼(如果有的話)的參數(shù)。
Example #1 連接到 MySQL
<?php $dbh = new PDO(’mysql:host=localhost;dbname=test’, $user, $pass);?>
如果有任何連接錯誤,將拋出一個?PDOException?異常對象。如果想處理錯誤狀態(tài),可以捕獲異常,或者選擇留給通過?set_exception_handler()?設置的應用程序全局異常處理程序。
Example #2 處理連接錯誤
<?php try {$dbh = new PDO(’mysql:host=localhost;dbname=test’, $user, $pass);foreach($dbh->query(’SELECT * from FOO’) as $row) { print_r($row);}$dbh = null; } catch (PDOException $e) {print 'Error!: ' . $e->getMessage() . '<br/>';die(); }?>
如果應用程序不在 PDO 構(gòu)造函數(shù)中捕獲異常,zend 引擎采取的默認動作是結(jié)束腳本并顯示一個回溯跟蹤,此回溯跟蹤可能泄漏完整的數(shù)據(jù)庫連接細節(jié),包括用戶名和密碼。因此有責任去顯式(通過?catch?語句)或隱式(通過?set_exception_handler()?)地捕獲異常。
連接數(shù)據(jù)成功后,返回一個 PDO 類的實例給腳本,此連接在 PDO 對象的生存周期中保持活動。要想關(guān)閉連接,需要銷毀對象以確保所有剩余到它的引用都被刪除,可以賦一個?NULL?值給對象變量。如果不明確地這么做,PHP 在腳本結(jié)束時會自動關(guān)閉連接。
Example #3 關(guān)閉一個連接
<?php $dbh = new PDO(’mysql:host=localhost;dbname=test’, $user, $pass); // 在此使用連接 // 現(xiàn)在運行完成,在此關(guān)閉連接 $dbh = null;?>
很多 web 應用程序通過使用到數(shù)據(jù)庫服務的持久連接獲得好處。持久連接在腳本結(jié)束后不會被關(guān)閉,且被緩存,當另一個使用相同憑證的腳本連接請求時被重用。持久連接緩存可以避免每次腳本需要與數(shù)據(jù)庫回話時建立一個新連接的開銷,從而讓 web 應用程序更快。
Example #4 持久化連接
<?php $dbh = new PDO(’mysql:host=localhost;dbname=test’, $user, $pass, array(PDO::ATTR_PERSISTENT => true ));?>
如果想使用持久連接,必須在傳遞給 PDO 構(gòu)造函數(shù)的驅(qū)動選項數(shù)組中設置?PDO::ATTR_PERSISTENT?。如果是在對象初始化之后用?PDO::setAttribute()?設置此屬性,則驅(qū)動程序?qū)⒉粫褂贸志眠B接。
如果使用 PDO ODBC 驅(qū)動且 ODBC 庫支持 ODBC 連接池(有unixODBC 和 Windows 兩種做法;可能會有更多),建議不要使用持久的 PDO 連接,而是把連接緩存留給 ODBC 連接池層處理。 ODBC 連接池在進程中與其他模塊共享;如果要求 PDO 緩存連接,則此連接絕不會被返回到 ODBC 連接池,導致創(chuàng)建額外的連接來服務其他模塊。
相關(guān)文章:
1. 利用CSS3新特性創(chuàng)建透明邊框三角2. vue前端RSA加密java后端解密的方法實現(xiàn)3. JSP+Servlet實現(xiàn)文件上傳到服務器功能4. 基于jsp+mysql實現(xiàn)在線水果銷售商城系統(tǒng)5. 基于javaweb+jsp實現(xiàn)企業(yè)財務記賬管理系統(tǒng)6. CSS可以做的幾個令你嘆為觀止的實例分享7. ASP動態(tài)網(wǎng)頁制作技術(shù)經(jīng)驗分享8. ASP中實現(xiàn)字符部位類似.NET里String對象的PadLeft和PadRight函數(shù)9. php使用正則驗證密碼字段的復雜強度原理詳細講解 原創(chuàng)10. 淺談由position屬性引申的css進階討論

網(wǎng)公網(wǎng)安備