国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

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

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

瀏覽:87日期: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)文章:
主站蜘蛛池模板: 久久久久久久久国产 | 国产精品高清在线观看93 | 亚洲成人自拍 | 中文字幕欧美在线观看 | 欧美激情一区二区亚洲专区 | 精品视频99 | 久草网在线 | 成年人在线观看视频免费 | 精品玖玖玖视频在线观看 | 久久99久久99精品观看 | 青青爽国产手机在线观看免费 | 中文字幕乱码在线观看 | 欧美一级毛片美99毛片 | 北岛玲亚洲一区在线观看 | 久草视频在| 久久99亚洲精品一区二区 | 亚洲视频在线观看免费 | 99精品一区二区三区 | 精品国产不卡一区二区三区 | 青青青免费手机版视频在线观看 | 国产日产欧产精品精品推荐小说 | 国产毛片久久久久久国产毛片 | 国产大秀视频 | 在线观看免费av网站 | 一级特级欧美a毛片免费 | 国产成人啪精品午夜在线观看 | 免费a级毛片视频 | 国产亚洲精品资源一区 | 亚洲天堂黄 | 久草在 | 免费国产高清视频 | 午夜欧美成人久久久久久 | 在线播放一区二区三区 | 亚洲国内精品自在线影视 | 免费人成在线观看网站 | 国产成人精品三级91在线影院 | 亚洲一区二区三 | 手机看片1024欧美日韩你懂的 | 三级网址免费 | 国产最新精品 | 日韩精品在线观看免费 |