PHP PDO連接
連接是通過創建 PDO 基類的實例而建立的。不管使用哪種驅動程序,都是用 PDO 類名。
連接到 MySQL
?php $dbh = new PDO('mysql:host=localhost;dbname=test', $user, $pass); ?>
注意:如果有任何連接錯誤,將拋出一個 PDOException 異常對象。
處理連接錯誤
?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的PDO預定義常量講解
下一篇:PHP的PDO事務與自動提交