W3Cschool
恭喜您成為首批注冊(cè)用戶
獲得88經(jīng)驗(yàn)值獎(jiǎng)勵(lì)
連接是通過(guò)創(chuàng)建 PDO 基類的實(shí)例而建立的。使用哪種驅(qū)動(dòng)程序并不重要,始終都會(huì)用 PDO 類名。構(gòu)造函數(shù)接受用于指定數(shù)據(jù)庫(kù)源(也稱為 DSN)以及可選的用戶名和密碼(如果有)的參數(shù)。
示例 #1 連接到 MySQL
<?php
$dbh = new PDO('mysql:host=localhost;dbname=test', $user, $pass);
?>
如果有任何連接錯(cuò)誤,將拋出 PDOException 對(duì)象。如果想處理錯(cuò)誤狀態(tài),可以捕獲異常,或者選擇將其留給 set_exception_handler() 設(shè)置的應(yīng)用程序全局異常處理程序。
示例 #2 處理連接錯(cuò)誤
<?php
try {
$dbh = new PDO('mysql:host=localhost;dbname=test', $user, $pass);
} catch (PDOException $e) {
// 對(duì)于示例,嘗試在超時(shí)后重新連接
}
就像其它任一 exception 一樣,PDOException 可以通過(guò) catch 語(yǔ)句手動(dòng)捕獲,也可以通過(guò) set_exception_handler() 自動(dòng)捕獲。否則,默認(rèn)行為是將未捕獲的異常轉(zhuǎn)換為 E_FATAL_ERROR。fatal 錯(cuò)誤可能會(huì)包含泄漏連接詳情的 backtrace。因此,生產(chǎn)服務(wù)器上的 php.ini 選項(xiàng) display_errors 應(yīng)設(shè)置為 0。
連接數(shù)據(jù)庫(kù)成功后,返回 PDO 類的實(shí)例給腳本。此連接在 PDO 對(duì)象的生存周期中保持有效狀態(tài)。要關(guān)閉連接,需要確保刪除它的所有剩余引用來(lái)銷毀對(duì)象——可以通過(guò)對(duì)對(duì)象變量賦值 null 來(lái)實(shí)現(xiàn)。如果沒(méi)有明確這么做,PHP 在腳本結(jié)束時(shí)會(huì)自動(dòng)關(guān)閉連接。
注意: 如果還有其它對(duì)此 PDO 實(shí)例的引用(比如來(lái)自 PDOStatement 實(shí)例,或來(lái)自其它同一 PDO 實(shí)例的其它變量),也必須刪除這些引用(例如,通過(guò)將 null 賦值給引用 PDOStatement 的變量)。
示例 #3 關(guān)閉連接
<?php
$dbh = new PDO('mysql:host=localhost;dbname=test', $user, $pass);
// 在此使用連接
$sth = $dbh->query('SELECT * FROM foo');
// 使用完畢,關(guān)閉連接
$sth = null;
$dbh = null;
?>
很多 web 應(yīng)用程序通過(guò)與數(shù)據(jù)庫(kù)建立持久連接獲得好處。持久連接不會(huì)在腳本結(jié)束時(shí)關(guān)閉,而是會(huì)緩存,且當(dāng)另一個(gè)腳本使用相同憑證請(qǐng)求連接時(shí)重用。持久連接緩存可以避免每次腳本需要與數(shù)據(jù)庫(kù)通信時(shí)建立新連接的開(kāi)銷,從而讓 web 應(yīng)用程序更快。
示例 #4 持久化連接
<?php
$dbh = new PDO('mysql:host=localhost;dbname=test', $user, $pass, array(
PDO::ATTR_PERSISTENT => true
));
?>
PDO::ATTR_PERSISTENT 選項(xiàng)的值轉(zhuǎn)換為 bool(啟用/禁用持久連接),除非它不是數(shù)字 string,在這種情況下允許使用多個(gè)持久連接池。如果不同的鏈接使用不兼容的設(shè)置,非常有用,例如 PDO::MYSQL_ATTR_USE_BUFFERED_QUERY 的值不同。
注意:如果想使用持久連接,必須在傳遞給 PDO 構(gòu)造函數(shù)的驅(qū)動(dòng)程序選項(xiàng)數(shù)組中設(shè)置 PDO::ATTR_PERSISTENT。如果在對(duì)象實(shí)例化后用 PDO::setAttribute() 設(shè)置此屬性,驅(qū)動(dòng)程序?qū)⒉粫?huì)使用持久連接。
注意:如果使用 PDO ODBC 驅(qū)動(dòng)程序且 ODBC 庫(kù)支持 ODBC 連接池(有 unixODBC 和 Windows 是其中的兩個(gè);可能會(huì)有更多),建議不要使用持久 PDO 連接,而是把連接緩存留給 ODBC 連接池層。ODBC 連接池在進(jìn)程中與其它模塊共享;如果 PDO 緩存連接,則此連接永遠(yuǎn)不會(huì)被返回到 ODBC 連接池,從而導(dǎo)致創(chuàng)建額外的連接來(lái)服務(wù)其它模塊。
Copyright©2021 w3cschool編程獅|閩ICP備15016281號(hào)-3|閩公網(wǎng)安備35020302033924號(hào)
違法和不良信息舉報(bào)電話:173-0602-2364|舉報(bào)郵箱:jubao@eeedong.com
掃描二維碼
下載編程獅App
編程獅公眾號(hào)
聯(lián)系方式:
更多建議: