色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

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

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

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

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

Example #1 連接到 MySQL

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

如果有任何連接錯(cuò)誤,將拋出一個(gè)?PDOException?異常對(duì)象。如果想處理錯(cuò)誤狀態(tài),可以捕獲異常,或者選擇留給通過?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é),包括用戶名和密碼。因此有責(zé)任去顯式(通過?catch?語句)或隱式(通過?set_exception_handler()?)地捕獲異常。

連接數(shù)據(jù)成功后,返回一個(gè) PDO 類的實(shí)例給腳本,此連接在 PDO 對(duì)象的生存周期中保持活動(dòng)。要想關(guān)閉連接,需要銷毀對(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)用程序通過使用到數(shù)據(jù)庫(kù)服務(wù)的持久連接獲得好處。持久連接在腳本結(jié)束后不會(huì)被關(guān)閉,且被緩存,當(dāng)另一個(gè)使用相同憑證的腳本連接請(qǐng)求時(shí)被重用。持久連接緩存可以避免每次腳本需要與數(shù)據(jù)庫(kù)回話時(shí)建立一個(gè)新連接的開銷,從而讓 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)建額外的連接來服務(wù)其他模塊。

標(biāo)簽: PHP
相關(guān)文章:
主站蜘蛛池模板: 黄色三级在线播放 | 欧美精品久久久久久久久大尺度 | 大视频在线爱爱爱爱 | 欧美亚洲国产精品久久久久 | 欧美在线乱妇一级毛片 | 97精品国产91久久久久久久 | 成人影视免费 | 玖玖国产在线 | a级特黄毛片免费观看 | 亚洲精品一区二区手机在线 | 在线国产二区 | 日韩中文字幕免费在线观看 | 日本人成18在线播放 | 久久777国产线看是看精品 | 欧美成人精品三级网站 | 欧美手机手机在线视频一区 | 午夜视频在线观看一区二区 | 国产成人精品曰本亚洲 | 999久久久精品视频在线观看 | 日韩专区亚洲国产精品 | 国产亚洲小视频 | 暖暖视频日韩欧美在线观看 | 精品国产亚洲人成在线 | 久久道| 在线观看亚洲免费视频 | 91精品国产免费网站 | 中国一级特黄剌激爽毛片 | 国产成人微拍精品 | 三级黄毛片 | 成人毛片在线播放 | 日本视频在线免费看 | 日本一级在线观看 | 亚洲欧美自拍一区 | 国产成人一区二区三区视频免费 | 国产爽的冒白浆的视频高清 | 欧美国产日本高清不卡 | 一级做a爰全过程免费视频毛片 | 中国一级毛片在线观看 | 国产在线更新 | 久久偷看各类wc女厕 | 香港日本韩国三级网站 |