PHP使用PDO 連接與連接管理操作實例分析
本文實例講述了PHP使用PDO 連接與連接管理操作。分享給大家供大家參考,具體如下:
連接是通過創(chuàng)建 PDO 基類的實例而建立的。不管使用哪種驅(qū)動程序,都是用 PDO 類名。
構(gòu)造函數(shù)接收用于指定數(shù)據(jù)庫源(所謂的 DSN)以及可能還包括用戶名和密碼(如果有的話)的參數(shù)。
連接到 MySQL
<?php $dbh = new PDO('mysql:host=localhost;dbname=test', $user, $pass); ?>
如果有任何連接錯誤,將拋出一個 PDOException 異常對象。如果想處理錯誤狀態(tài),可以捕獲異常,
或者選擇留給通過 set_exception_handler()設(shè)置的應(yīng)用程序全局異常處理程序。
處理連接錯誤
<?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ù)成功后,返回一個 PDO 類的實例給腳本,
此連接在 PDO 對象的生存周期中保持活動。
要想關(guān)閉連接,需要銷毀對象以確保所有剩余到它的引用都被刪除,可以賦一個 NULL
值給對象變量。
如果不明確地這么做,PHP 在腳本結(jié)束時會自動關(guān)閉連接。
關(guān)閉一個連接
<?php $dbh = new PDO('mysql:host=localhost;dbname=test', $user, $pass); // 在此使用連接 // 現(xiàn)在運行完成,在此關(guān)閉連接 $dbh = null; ?>
很多 web 應(yīng)用程序通過使用到數(shù)據(jù)庫服務(wù)的持久連接獲得好處。持久連接在腳本結(jié)束后不會被關(guān)閉,且被緩存,
當(dāng)另一個使用相同憑證的腳本連接請求時被重用。持久連接緩存可以避免每次腳本需要與數(shù)據(jù)庫回話時建立一個新連接的開銷,從而讓 web 應(yīng)用程序更快。
持久化連接
<?php $dbh = new PDO('mysql:host=localhost;dbname=test', $user, $pass, array( PDO::ATTR_PERSISTENT => true )); ?>
如果想使用持久連接,必須在傳遞給 PDO 構(gòu)造函數(shù)的驅(qū)動選項數(shù)組中設(shè)置 PDO::ATTR_PERSISTENT
。
如果是在對象初始化之后用 PDO::setAttribute() 設(shè)置此屬性,則驅(qū)動程序?qū)⒉粫褂贸志眠B接。
更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《PHP基于pdo操作數(shù)據(jù)庫技巧總結(jié)》、《php+mysqli數(shù)據(jù)庫程序設(shè)計技巧總結(jié)》、《php面向?qū)ο蟪绦蛟O(shè)計入門教程》、《php字符串(string)用法總結(jié)》、《php+mysql數(shù)據(jù)庫操作入門教程》及《php常見數(shù)據(jù)庫操作技巧匯總》
希望本文所述對大家PHP程序設(shè)計有所幫助。
- PHP PDO預(yù)處理語句及事務(wù)的使用
- PHP如何初始化PDO及原始SQL語句操作
- PHP中PDO關(guān)閉連接的方法問題
- php+pdo實現(xiàn)的購物車類完整示例
- PHP使用PDO實現(xiàn)mysql防注入功能詳解
- PHP PDO和消息隊列的個人理解與應(yīng)用實例分析
- php pdo連接數(shù)據(jù)庫操作示例
- PHP連接MySQL數(shù)據(jù)庫的三種方式實例分析【mysql、mysqli、pdo】
- PHP使用PDO創(chuàng)建MySQL數(shù)據(jù)庫、表及插入多條數(shù)據(jù)操作示例
- php如何用PDO操作大數(shù)據(jù)對象
相關(guān)文章
PHP使用CURL實現(xiàn)多線程抓取網(wǎng)頁
PHP 利用 Curl 可以完成各種傳送文件操作,比如模擬瀏覽器發(fā)送GET,POST請求等等,然而因為php語言本身不支持多線程,所以開發(fā)爬蟲程序效率并不高,不過可以用 Curl ,借助Curl 這個功能實現(xiàn)并發(fā)多線程的訪問多個url地址以實現(xiàn)并發(fā)多線程抓取網(wǎng)頁或者下載文件2015-04-04基于Surprise協(xié)同過濾實現(xiàn)短視頻推薦方法示例
這篇文章主要為大家介紹了基于Surprise協(xié)同過濾實現(xiàn)短視頻推薦方法示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-07-07PHP三層結(jié)構(gòu)(下) PHP實現(xiàn)AOP
讓我們把注意力集中到中間服務(wù)層上來。中間服務(wù)層代碼比較簡單,只是調(diào)用數(shù)據(jù)訪問層代碼將留言保存到數(shù)據(jù)庫。2010-07-07php中將地址生成迅雷快車旋風(fēng)鏈接的代碼[測試通過]
php中將地址生成迅雷快車旋風(fēng)鏈接的代碼,非常不錯,將下面的代碼保存為cs.php運行即可。2011-04-04php 使用file_get_contents讀取大文件的方法
本文介紹了在php中使用file_get_contents函數(shù)讀取大文件的方法,并附上了示例以及使用小技巧,非常的實用,這里推薦給大家2014-11-11