国产成人精品亚洲777人妖,欧美日韩精品一区视频,最新亚洲国产,国产乱码精品一区二区亚洲

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

PHP數(shù)據(jù)庫(kù)抽象層之PDO(二)——連接與連接管理

瀏覽:145日期:2022-09-15 15:43:09

連接是通過(guò)創(chuàng)建 PDO 基類(lèi)的實(shí)例而建立的。不管使用哪種驅(qū)動(dòng)程序,都是用 PDO 類(lèi)名。構(gòu)造函數(shù)接收用于指定數(shù)據(jù)庫(kù)源(所謂的 DSN)以及可能還包括用戶(hù)名和密碼(如果有的話(huà))的參數(shù)。

Example #1 連接到 MySQL

<?php $dbh = new PDO(’mysql:host=localhost;dbname=test’, $user, $pass);?>

如果有任何連接錯(cuò)誤,將拋出一個(gè)?PDOException?異常對(duì)象。如果想處理錯(cuò)誤狀態(tài),可以捕獲異常,或者選擇留給通過(guò)?set_exception_handler()?設(shè)置的應(yīng)用程序全局異常處理程序。

Example #2 處理連接錯(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(); }?>

如果應(yīng)用程序不在 PDO 構(gòu)造函數(shù)中捕獲異常,zend 引擎采取的默認(rèn)動(dòng)作是結(jié)束腳本并顯示一個(gè)回溯跟蹤,此回溯跟蹤可能泄漏完整的數(shù)據(jù)庫(kù)連接細(xì)節(jié),包括用戶(hù)名和密碼。因此有責(zé)任去顯式(通過(guò)?catch?語(yǔ)句)或隱式(通過(guò)?set_exception_handler()?)地捕獲異常。

連接數(shù)據(jù)成功后,返回一個(gè) PDO 類(lèi)的實(shí)例給腳本,此連接在 PDO 對(duì)象的生存周期中保持活動(dòng)。要想關(guān)閉連接,需要銷(xiāo)毀對(duì)象以確保所有剩余到它的引用都被刪除,可以賦一個(gè)?NULL?值給對(duì)象變量。如果不明確地這么做,PHP 在腳本結(jié)束時(shí)會(huì)自動(dòng)關(guān)閉連接。

Example #3 關(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ù)回話(huà)時(shí)建立一個(gè)新連接的開(kāi)銷(xiāo),從而讓 web 應(yīng)用程序更快。

Example #4 持久化連接

<?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ì)使用持久連接。

如果使用 PDO ODBC 驅(qū)動(dòng)且 ODBC 庫(kù)支持 ODBC 連接池(有unixODBC 和 Windows 兩種做法;可能會(huì)有更多),建議不要使用持久的 PDO 連接,而是把連接緩存留給 ODBC 連接池層處理。 ODBC 連接池在進(jìn)程中與其他模塊共享;如果要求 PDO 緩存連接,則此連接絕不會(huì)被返回到 ODBC 連接池,導(dǎo)致創(chuàng)建額外的連接來(lái)服務(wù)其他模塊。

標(biāo)簽: PHP
相關(guān)文章:
主站蜘蛛池模板: 新绛县| 万年县| 易门县| 怀来县| 明水县| 麟游县| 安溪县| 云梦县| 偃师市| 嵩明县| 芷江| 汝州市| 陵川县| 鱼台县| 广德县| 通榆县| 白玉县| 滕州市| 顺义区| 遂川县| 临泽县| 兰坪| 独山县| 达孜县| 石河子市| 正蓝旗| 襄樊市| 营山县| 时尚| 贵德县| 木里| 团风县| 陇川县| 保康县| 双桥区| 博爱县| 旺苍县| 泌阳县| 社旗县| 石城县| 靖安县|