PHP數(shù)據(jù)庫(kù)抽象層之PDO(二)——連接與連接管理
連接是通過(guò)創(chuàng)建 PDO 基類(lèi)的實(shí)例而建立的。不管使用哪種驅(qū)動(dòng)程序,都是用 PDO 類(lèi)名。構(gòu)造函數(shù)接收用于指定數(shù)據(jù)庫(kù)源(所謂的 DSN)以及可能還包括用戶(hù)名和密碼(如果有的話(huà))的參數(shù)。
Example #1 連接到 MySQL
<?php $dbh = new PDO(’mysql:host=localhost;dbname=test’, $user, $pass);?>
如果有任何連接錯(cuò)誤,將拋出一個(gè)?PDOException?異常對(duì)象。如果想處理錯(cuò)誤狀態(tài),可以捕獲異常,或者選擇留給通過(guò)?set_exception_handler()?設(shè)置的應(yīng)用程序全局異常處理程序。
Example #2 處理連接錯(cuò)誤
<?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(); }?>
如果應(yīng)用程序不在 PDO 構(gòu)造函數(shù)中捕獲異常,zend 引擎采取的默認(rèn)動(dòng)作是結(jié)束腳本并顯示一個(gè)回溯跟蹤,此回溯跟蹤可能泄漏完整的數(shù)據(jù)庫(kù)連接細(xì)節(jié),包括用戶(hù)名和密碼。因此有責(zé)任去顯式(通過(guò)?catch?語(yǔ)句)或隱式(通過(guò)?set_exception_handler()?)地捕獲異常。
連接數(shù)據(jù)成功后,返回一個(gè) PDO 類(lèi)的實(shí)例給腳本,此連接在 PDO 對(duì)象的生存周期中保持活動(dòng)。要想關(guān)閉連接,需要銷(xiāo)毀對(duì)象以確保所有剩余到它的引用都被刪除,可以賦一個(gè)?NULL?值給對(duì)象變量。如果不明確地這么做,PHP 在腳本結(jié)束時(shí)會(huì)自動(dòng)關(guān)閉連接。
Example #3 關(guān)閉一個(gè)連接
<?php $dbh = new PDO(’mysql:host=localhost;dbname=test’, $user, $pass); // 在此使用連接 // 現(xiàn)在運(yùn)行完成,在此關(guān)閉連接 $dbh = null;?>
很多 web 應(yīng)用程序通過(guò)使用到數(shù)據(jù)庫(kù)服務(wù)的持久連接獲得好處。持久連接在腳本結(jié)束后不會(huì)被關(guān)閉,且被緩存,當(dāng)另一個(gè)使用相同憑證的腳本連接請(qǐng)求時(shí)被重用。持久連接緩存可以避免每次腳本需要與數(shù)據(jù)庫(kù)回話(huà)時(shí)建立一個(gè)新連接的開(kāi)銷(xiāo),從而讓 web 應(yīng)用程序更快。
Example #4 持久化連接
<?php $dbh = new PDO(’mysql:host=localhost;dbname=test’, $user, $pass, array(PDO::ATTR_PERSISTENT => true ));?>
如果想使用持久連接,必須在傳遞給 PDO 構(gòu)造函數(shù)的驅(qū)動(dòng)選項(xiàng)數(shù)組中設(shè)置?PDO::ATTR_PERSISTENT?。如果是在對(duì)象初始化之后用?PDO::setAttribute()?設(shè)置此屬性,則驅(qū)動(dòng)程序?qū)⒉粫?huì)使用持久連接。
如果使用 PDO ODBC 驅(qū)動(dòng)且 ODBC 庫(kù)支持 ODBC 連接池(有unixODBC 和 Windows 兩種做法;可能會(huì)有更多),建議不要使用持久的 PDO 連接,而是把連接緩存留給 ODBC 連接池層處理。 ODBC 連接池在進(jìn)程中與其他模塊共享;如果要求 PDO 緩存連接,則此連接絕不會(huì)被返回到 ODBC 連接池,導(dǎo)致創(chuàng)建額外的連接來(lái)服務(wù)其他模塊。
相關(guān)文章:
1. Python調(diào)用接口合并Excel表代碼實(shí)例2. .net如何優(yōu)雅的使用EFCore實(shí)例詳解3. Python快速將ppt制作成配音視頻課件的操作方法4. ASP.Net Core對(duì)USB攝像頭進(jìn)行截圖5. 一文透徹詳解.NET框架類(lèi)型系統(tǒng)設(shè)計(jì)要點(diǎn)6. 通過(guò)CSS數(shù)學(xué)函數(shù)實(shí)現(xiàn)動(dòng)畫(huà)特效7. ASP.NET MVC使用Boostrap實(shí)現(xiàn)產(chǎn)品展示、查詢(xún)、排序、分頁(yè)8. 通過(guò)Ajax方式綁定select選項(xiàng)數(shù)據(jù)的實(shí)例9. ASP.NET MVC實(shí)現(xiàn)橫向展示購(gòu)物車(chē)10. ajax動(dòng)態(tài)加載json數(shù)據(jù)并詳細(xì)解析
