溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

php怎樣關(guān)閉pdo

發(fā)布時(shí)間:2020-11-06 09:58:59 來(lái)源:億速云 閱讀:177 作者:小新 欄目:編程語(yǔ)言

小編給大家分享一下php怎樣關(guān)閉pdo,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

php關(guān)閉pdo的方法:首先通過(guò)PHP連接到MySQL;然后返回一個(gè)PDO類的實(shí)例給腳本;最后通過(guò)賦一個(gè)NULL值給對(duì)象變量來(lái)實(shí)現(xiàn)關(guān)閉連接。

PHP PDO連接

連接是通過(guò)創(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)用程序通過(guò)使用到數(shù)據(jù)庫(kù)服務(wù)的持久連接獲得好處。

持久連接在腳本結(jié)束后不會(huì)被關(guān)閉,且被緩存,當(dāng)另一個(gè)使用相同憑證的腳本連接請(qǐng)求時(shí)被重用。

持久連接緩存可以避免每次腳本需要與數(shù)據(jù)庫(kù)回話時(shí)建立一個(gè)新連接的開(kāi)銷,從而讓 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ì)使用持久連接。

以上是php怎樣關(guān)閉pdo的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問(wèn)一下細(xì)節(jié)
推薦閱讀:
  1. PHP之PDO
  2. 什么是php的pdo

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI