PHP的PDO連接講解
PHP PDO連接
連接是通過創(chuàng)建 PDO 基類的實(shí)例而建立的。不管使用哪種驅(qū)動(dòng)程序,都是用 PDO 類名。
連接到 MySQL
<?php
$dbh = new PDO('mysql:host=localhost;dbname=test', $user, $pass);
?>
注意:如果有任何連接錯(cuò)誤,將拋出一個(gè) PDOException 異常對(duì)象。
處理連接錯(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();
}
?>
連接數(shù)據(jù)成功后,返回一個(gè) PDO 類的實(shí)例給腳本,此連接在 PDO 對(duì)象的生存周期中保持活動(dòng)。
要想關(guān)閉連接,需要銷毀對(duì)象以確保所有剩余到它的引用都被刪除,可以賦一個(gè) NULL 值給對(duì)象變量。
如果不這么做,PHP 在腳本結(jié)束時(shí)會(huì)自動(dòng)關(guān)閉連接。
關(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)用程序通過使用到數(shù)據(jù)庫(kù)服務(wù)的持久連接獲得好處。
持久連接在腳本結(jié)束后不會(huì)被關(guān)閉,且被緩存,當(dāng)另一個(gè)使用相同憑證的腳本連接請(qǐng)求時(shí)被重用。
持久連接緩存可以避免每次腳本需要與數(shù)據(jù)庫(kù)回話時(shí)建立一個(gè)新連接的開銷,從而讓 web 應(yīng)用程序更快。
持久化連接
<?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ì)使用持久連接。
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)腳本之家的支持。如果你想了解更多相關(guān)內(nèi)容請(qǐng)查看下面相關(guān)鏈接
相關(guān)文章
不用GD庫(kù)生成當(dāng)前時(shí)間的PNG格式圖象的程序
不用GD庫(kù)生成當(dāng)前時(shí)間的PNG格式圖象的程序...2006-10-10
Apache環(huán)境下PHP利用HTTP緩存協(xié)議原理解析及應(yīng)用分析
http協(xié)議里控制瀏覽器緩存的頭有三個(gè)Cache-Control,Expires,Last-Modified2010-02-02
PHP編碼規(guī)范之注釋和文件結(jié)構(gòu)說明
理解學(xué)習(xí)PHP編碼規(guī)范之注釋和文件結(jié)構(gòu),編寫規(guī)則的代碼與目錄結(jié)構(gòu)讓大家能快速的熟悉。提高協(xié)同工作效率。2010-07-07
利用PHP創(chuàng)建動(dòng)態(tài)圖像
利用PHP創(chuàng)建動(dòng)態(tài)圖像...2006-10-10

