連線是透過建立PDO 基底類別的實例而建立的。不管使用哪種驅動程序,都是用PDO 類別名稱。
<?php$dbh = new PDO('mysql:host=localhost;dbname=test', $user, $pass);?>
注意:如果有任何連線錯誤,將拋出一個PDOException 例外物件。
<?phptry { $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() 設定此屬性,則驅動程式將不會使用持久連線。