欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳解PHP中的PDO類

 更新時間:2015年07月06日 09:43:58   投稿:goldensun  
這篇文章主要介紹了詳解PHP中的PDO類,PDO類可以幫助人們更加方便地在PHP中使用數(shù)據(jù)庫,需要的朋友可以參考下

 簡介

咱一起來看看PDO類。PDO是PHP Data Objects的縮寫,它被描述為“在PHP中訪問數(shù)據(jù)庫的輕量級,兼容性的接口”。盡管它的名字不咋好聽,但PDO是一個在PHP中訪問數(shù)據(jù)庫會讓人喜愛的方式。
與MySQLi的不同

MySQLi和PDO很相似,都有兩方面主要區(qū)別:

1.MySQLi只能訪問MySQL,但PDO可以訪問12種不同的數(shù)據(jù)庫

2.PDO沒有普通函數(shù)調(diào)用(mysqli_*functions)
開始步驟

首先,你得確定一下你的PHP是否安裝了PDO插件。你可以用$test=new PDO()的結(jié)果來測試。如果提示說是參數(shù)不匹配,那證明已經(jīng)安裝了PDO插件,如果說是對象不存在,你得先確認(rèn)一下在pho.ini中php_pdo_yourssqlserverhere.extis是否被注釋掉了。如果沒有這句話,那你得安裝PDO了,這里就不啰嗦了。

連接

現(xiàn)在我們確認(rèn)服務(wù)器已經(jīng)工作,開始連接數(shù)據(jù)庫吧:
 

$dsn = 'mysql:dbname=demo;host=localhost;port=3306';
$username = 'root';
$password = 'password_here';
try {
 $db = new PDO($dsn, $username, $password); // also allows an extra parameter of configuration
} catch(PDOException $e) {
 die('Could not connect to the database:<br/>' . $e);
}

除$dsn之外,所有語句和變量都能自我解釋。DSN指的是數(shù)據(jù)源名稱,有多種輸入類型。最常見的一種是我們剛剛用的這種,PHP官網(wǎng)解釋了 其他可用的DSN 。

你可以省去DSN的其他額外參數(shù),只需要在數(shù)據(jù)庫驅(qū)動后面帶個冒號,比如(mysql:)。在這種情況下PDO將會嘗試連接到本地數(shù)據(jù)庫。就像當(dāng)你使用MySQLi時需要在查詢中指定數(shù)據(jù)庫名稱一樣。

最后一件你需要注意的事情就是我們用try-catch塊包裹了我們的初始化對象。PDO連接失敗的時候?qū)伋鯬DOException異常而不是查詢失敗的時候。如果你愿意你可以使用下面代碼$db=line來選擇異常的模式。
 

$db->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);

或者你可以直接在PDO初始化時傳遞參數(shù):
 

$db = new PDO($dsn, $username, $password, array (
 PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION
));

我們現(xiàn)在使用的是錯誤的方式——在失敗時候簡單返回false,我們是沒有理由不對異常進行處理的。

基本查詢

在PDO中使用query和exec兩種方法使得對數(shù)據(jù)庫查詢變得非常簡單。如果你想得到查詢結(jié)果的行數(shù)exec是非常好用的,因此對SELECT查詢語句是非常有用的。

現(xiàn)在我們通過下面的一個例子查看這兩種方法:
 

$statement = <<<SQL
 SELECT *
 FROM `foods`
 WHERE `healthy` = 0
SQL;
 
$foods = $db->query($statement);

假設(shè)我們的查詢是正確的,$foods現(xiàn)在是一個PDO Statement對象,我們可以用它獲取到我們的結(jié)果或者是查看這次查詢中一共查到多少條結(jié)果集。
行數(shù)

不足的是,PDO沒有提供一個統(tǒng)一的方法去計算返回的行數(shù)。PDO Statement包含了一個叫做rowCount的方法,但是這個方法卻不能保證在每一個SQL驅(qū)動中起作用(幸運的是,它能夠在Mysql數(shù)據(jù)庫中起作用)。

如果你的SQL驅(qū)動不支持這個方法,你也有2個選擇:使用二次查詢(SELECT COUNT(*))或者使用簡單的count($foods)得到行數(shù)。

幸運的是對我們的MySQL例子,我們可以使用下面的簡單方法來輸出正確的行數(shù)。
 

echo $foods->rowCount();

遍歷結(jié)果集

打印出這些可口的食物一點也不困難:
 

foreach($foods->FetchAll() as $food) {
 echo $food['name'] . '<br />';
}

唯一需要注意的是PDO也支持Fetch方法,這個方法只會返回第一條結(jié)果,這對于只需要查詢一條結(jié)果集是非常有用的。
轉(zhuǎn)義用戶輸入(的特殊字符)

你可曾聽說過(mysqli_)real_escape_string,這是用于確保用戶輸入安全數(shù)據(jù)。PDO提供了一個方法叫做quote,這個方法可以把輸入字符串中帶有引號的地方進行特殊字符轉(zhuǎn)義。
 

$input: this is's' a '''pretty dange'rous str'ing

在轉(zhuǎn)義后,最終得到下面結(jié)果:
 

$db->quote($input): 'this is\'s\' a \'\'\'pretty dange\'rous str\'ing'
exec()

正如上面提到的,你可以使用exec()方法實現(xiàn)UPDATE,DELETE和INSERT 操作,執(zhí)行后它會返回受影響行數(shù)的數(shù)量:
 

$statement = <<<SQL
 DELETE FROM `foods`
 WHERE `healthy` = 1;
SQL;
 
echo $db->exec($statement); // outputs number of deleted rows

預(yù)處理語句

盡管exec方法和查詢在PHP中仍然被大量使用和支持,但是PHP官網(wǎng)上還是要求大家用預(yù)處理語句的方式來替代。為什么呢?主要是因為:它更安全。預(yù)處理語句不會直接在實際查詢中插入?yún)?shù),這就避免了許多潛在的SQL注入。

然而出于某種原因,PDO實際上并沒有真正的使用預(yù)處理,它是在模擬預(yù)處理方式,在將語句傳給SQL服務(wù)器之前會把參數(shù)數(shù)據(jù)插入到語句中,這使得某些系統(tǒng)容易受到SQL注入。

如果你的SQL服務(wù)器不真正的支持預(yù)處理,我們可以很容易的通過如下方式在PDO初始化時傳參來修復(fù)這個問題:
 

$db->setAttribute(PDO::ATTR_EMULATE_PREPARES, false);

接下來開始我們的第一個預(yù)處理語句吧:
 

$statement = $db->prepare('SELECT * FROM foods WHERE `name`=? AND `healthy`=?');
$statement2 = $db->prepare('SELECT * FROM foods WHERE `name`=:name AND `healthy`=:healthy)';

正如你所見,有兩種創(chuàng)建參數(shù)的方法,命名的與匿名的(不可以同時出現(xiàn)在一個語句中)。然后你可以使用bindValue來敲進你的輸入:
 

$statement->bindValue(1, 'Cake');
$statement->bindValue(2, true);
 
$statement2->bindValue(':name', 'Pie');
$statement2->bindValue(':healthy', false);

注意使用命名參數(shù)的時候你要包含進冒號(:)。PDO還有一個bindParam方法,可以通過引用綁定數(shù)值,也就是說它只在語句執(zhí)行的時候查找相應(yīng)數(shù)值。

現(xiàn)在剩下的唯一要做的事情,就是執(zhí)行我們的語句:
 

$statement->execute();
$statement2->execute();
 
// Get our results:
$cake = $statement->Fetch();
$pie = $statement2->Fetch();

為了避免只使用bindValue帶來的代碼碎片,你可以用數(shù)組給execute方法作為參數(shù),像這樣:
 

$statement->execute(array(1 => 'Cake', 2 => true));
$statement2->execute(array(':name' => 'Pie', ':healthy' => false));

事務(wù)

前面我們已經(jīng)描述過了什么是事務(wù):

一個事務(wù)就是執(zhí)行一組查詢,但是并不保存他們的影響到數(shù)據(jù)庫中。這樣做的好處是如果你執(zhí)行了4條相互依賴的插入語句,當(dāng)有一條失敗后,你可以回滾使得其他的數(shù)據(jù)不能夠插入到數(shù)據(jù)庫中,確保相互依賴的字段能夠正確的插入。你需要確保你使用的數(shù)據(jù)庫引擎支持事務(wù)。
開啟事務(wù)

你可以很簡單的使用beginTransaction()方法開啟一個事務(wù):
 

$db->beginTransaction();
 
$db->inTransaction(); // true!

然后你可以繼續(xù)執(zhí)行你的數(shù)據(jù)庫操作語句,在最后提交事務(wù):
 

$db->commit();

還有類似MySQLi中的rollBack()方法,但是它并不是回滾所有的類型(例如在MySQL中使用DROP TABLE),這個方法并不是真正的可靠,我建議盡量避免依賴此方法。

其他有用的選項

有幾個選項你可以考慮用一下。這些可以作為你的對象初始化時候的第四個參數(shù)輸入。

 
$options = array($option1 => $value1, $option[..]);
$db = new PDO($dsn, $username, $password, $options);
PDO::ATTR_DEFAULT_FETCH_MODE

你可以選擇PDO將返回的是什么類型的結(jié)果集,如PDO::FETCH_ASSOC,會允許你使用$result['column_name'],或者PDO::FETCH_OBJ,會返回一個匿名對象,以便你使用$result->column_name

你還可以將結(jié)果放入一個特定的類(模型),可以通過給每一個單獨的查詢設(shè)置一個讀取模式,就像這樣:
 

$query = $db->query('SELECT * FROM `foods`');
$foods = $query->fetchAll(PDO::FETCH_CLASS, 'Food');
PDO::ATTR_ERRMODE
- 所有讀取模式

上面我們已經(jīng)解釋過這一條了,但喜歡TryCatch的人需要用到:PDO::ERRMODE_EXCEPTION。如果不論什么原因你想拋出PHP警告,就使用PDO::ERRMODE_WARNING。

PDO::ATTR_TIMEOUT

當(dāng)你為載入時間而著急時,你可以使用此屬性來為你的查詢指定一個超時時間,單位是秒. 注意,如果超過你設(shè)置的時間,缺省會拋出E_WARNING異常, 除非 PDO::ATTR_ERRMODE 被改變.

更多屬性信息可以在 PHP官網(wǎng)的屬性設(shè)置 里查看到.
最后的思考

PDO是一個在PHP中訪問你的數(shù)據(jù)庫的很棒的方式,可以認(rèn)為是最好的方式。除非你拒絕使用面向?qū)ο蟮姆椒ɑ蚴翘?xí)慣 MySQLi 的方法名稱,否則沒有理由不使用PDO。

更好的是完全切換到只使用預(yù)處理語句,這最終將使你的生活更輕松!

相關(guān)文章

  • php token使用與驗證示例【測試可用】

    php token使用與驗證示例【測試可用】

    這篇文章主要介紹了php token使用與驗證方法,通過對form表單hidden提交字段的處理實現(xiàn)token驗證功能,防止非法來源數(shù)據(jù)的訪問,需要的朋友可以參考下
    2017-08-08
  • 一個php短網(wǎng)址的生成代碼(仿微博短網(wǎng)址)

    一個php短網(wǎng)址的生成代碼(仿微博短網(wǎng)址)

    這篇文章主要介紹了一個php短網(wǎng)址的生成代碼(仿微博短網(wǎng)址),需要的朋友可以參考下
    2014-05-05
  • PHP安全配置

    PHP安全配置

    PHP其實不過是Web服務(wù)器的一個模塊功能,所以首先要保證Web服務(wù)器的安全。當(dāng)然Web服務(wù)器要安全又必須是先保證系統(tǒng)安全,這樣就扯遠了,無窮無盡
    2006-12-12
  • PHP WebSocket的技術(shù)解析與使用指南詳解

    PHP WebSocket的技術(shù)解析與使用指南詳解

    在這篇文章中我們將深入討論從建立連接、綁定到監(jiān)聽等各方面的操作,并提供易于理解和實踐的指導(dǎo),希望可以幫助大家掌握在PHP中使用WebSocket的關(guān)鍵概念和技術(shù)
    2024-02-02
  • PHP中PCRE正則解析代碼詳解

    PHP中PCRE正則解析代碼詳解

    在本篇文章里小編給大家分享了關(guān)于PHP中PCRE正則解析的相關(guān)知識點內(nèi)容,需要的朋友們學(xué)習(xí)下。
    2019-04-04
  • PHP的explode和implode的使用說明

    PHP的explode和implode的使用說明

    下里說道php中的explode 和implode的用法,芭蕾舞鞋,盼望對于友朋們有所輔助!
    2011-07-07
  • 修改PHP腳本使WordPress攔截垃圾評論的方法示例

    修改PHP腳本使WordPress攔截垃圾評論的方法示例

    這篇文章主要介紹了修改PHP腳本使WordPress攔截垃圾評論的方法示例,主要是通過修改主題的functions.php來實現(xiàn)相關(guān)功能,需要的朋友可以參考下
    2015-12-12
  • php微信支付接口開發(fā)程序

    php微信支付接口開發(fā)程序

    微信支付接口現(xiàn)在也慢慢的像支付寶一個可以利用api接口來實現(xiàn)第三方網(wǎng)站或應(yīng)用進行支付了,下文整理了一個php微信支付接口開發(fā)程序并且己測試,感興趣的小伙伴們可以參考一下
    2016-08-08
  • PHP輸出Excel PHPExcel的方法

    PHP輸出Excel PHPExcel的方法

    這篇文章主要為大家詳細介紹了PHP輸出Excel PHPExcel的方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-07-07
  • php線性表順序存儲實現(xiàn)代碼(增刪查改)

    php線性表順序存儲實現(xiàn)代碼(增刪查改)

    php實現(xiàn)線性表順序存儲的代碼,需要的朋友可以參考下
    2012-02-02

最新評論