本文實例講述了PHP使用PDO 連接與連接管理操作。分享給大家供大家參考,具體如下:
連接是通過創建 PDO 基類的實例而建立的。不管使用哪種驅動程序,都是用 PDO 類名。
構造函數接收用于指定數據庫源(所謂的 DSN)以及可能還包括用戶名和密碼(如果有的話)的參數。
連接到 MySQL
?php
$dbh = new PDO('mysql:host=localhost;dbname=test', $user, $pass);
?>
如果有任何連接錯誤,將拋出一個 PDOException 異常對象。如果想處理錯誤狀態,可以捕獲異常,
或者選擇留給通過 set_exception_handler()設置的應用程序全局異常處理程序。
處理連接錯誤
?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 類的實例給腳本,
此連接在 PDO 對象的生存周期中保持活動。
要想關閉連接,需要銷毀對象以確保所有剩余到它的引用都被刪除,可以賦一個 NULL
值給對象變量。
如果不明確地這么做,PHP 在腳本結束時會自動關閉連接。
關閉一個連接
?php
$dbh = new PDO('mysql:host=localhost;dbname=test', $user, $pass);
// 在此使用連接
// 現在運行完成,在此關閉連接
$dbh = null;
?>
很多 web 應用程序通過使用到數據庫服務的持久連接獲得好處。持久連接在腳本結束后不會被關閉,且被緩存,
當另一個使用相同憑證的腳本連接請求時被重用。持久連接緩存可以避免每次腳本需要與數據庫回話時建立一個新連接的開銷,從而讓 web 應用程序更快。
持久化連接
?php
$dbh = new PDO('mysql:host=localhost;dbname=test', $user, $pass, array(
PDO::ATTR_PERSISTENT => true
));
?>
如果想使用持久連接,必須在傳遞給 PDO 構造函數的驅動選項數組中設置 PDO::ATTR_PERSISTENT
。
如果是在對象初始化之后用 PDO::setAttribute() 設置此屬性,則驅動程序將不會使用持久連接。
更多關于PHP相關內容感興趣的讀者可查看本站專題:《PHP基于pdo操作數據庫技巧總結》、《php+mysqli數據庫程序設計技巧總結》、《php面向對象程序設計入門教程》、《php字符串(string)用法總結》、《php+mysql數據庫操作入門教程》及《php常見數據庫操作技巧匯總》
希望本文所述對大家PHP程序設計有所幫助。
您可能感興趣的文章:- PHP PDO預處理語句及事務的使用
- PHP如何初始化PDO及原始SQL語句操作
- PHP中PDO關閉連接的方法問題
- php+pdo實現的購物車類完整示例
- PHP使用PDO實現mysql防注入功能詳解
- PHP PDO和消息隊列的個人理解與應用實例分析
- php pdo連接數據庫操作示例
- PHP連接MySQL數據庫的三種方式實例分析【mysql、mysqli、pdo】
- PHP使用PDO創建MySQL數據庫、表及插入多條數據操作示例
- php如何用PDO操作大數據對象