亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

PHP PDO操作總結

2019-11-20 13:55:18
字體:
來源:轉載
供稿:網友

0x01:測試PDO是否安裝成功

運行如下代碼,如果提示參數錯誤,說明PDO已經安裝,如果說明對象不存在,則修改PHP配置文件php.ini,取消php_pdo_yourssqlserverhere.extis前面的注釋。

復制代碼 代碼如下:

$test=new PDO();

0x02:連接數據庫

運行Apache服務器,確定服務器已經運行并且PDO安裝成功,那么下面我們就來連接數據庫吧。

復制代碼 代碼如下:

$dsn = 'mysql:dbname=demo;host=localhost;port=3306';
$username = 'root';
$password = 'password_here';
try {
    $db = new PDO($dsn, $username, $password);
} catch(PDOException $e) {
    die('Could not connect to the database:
' . $e);
}

0x03:基本查詢

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

復制代碼 代碼如下:

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

如果上面的查詢是正確的,則$foods現在是一個PDO Statement對象,我們可以從這個對象中獲取我們需要的結果和一共查詢到了多少結果集。

0x04:獲取行數

如果利用的是Mysql數據庫,PDO Statement中包含了一個rowCount的方法可以獲取結果集中的行數,如下代碼所示:

復制代碼 代碼如下:

echo $foods->rowCount;

0x05:遍歷結果集

PDO Statment可以使用forech語句進行遍歷,如下面代碼所示:

復制代碼 代碼如下:

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

PDO也支持Fetch方法,這個方法只返回第一條結果。

0x06:轉義用戶輸入的特殊字符

PDO提供了一個方法叫做quote,這個方法可以把輸入字符串中帶有引號的地方進行特殊字符轉義。

復制代碼 代碼如下:

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

使用quote方法轉移后:

復制代碼 代碼如下:

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

0x07:exec()

PDO可以使用exec()方法實現UPDATE,DELETE和INSERT 操作,執行后它會返回受影響行數的數量:

復制代碼 代碼如下:

$statement = <<<SQL
    DELETE FROM `foods`
    WHERE `healthy` = 1;
SQL;
echo $db->exec($statement);

0x08:預處理語句

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

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

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

復制代碼 代碼如下:

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

下面是我們的第一個預處理語句:

復制代碼 代碼如下:

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

如上面的代碼所示,有兩種創建參數的方法,命名的與匿名的(不可以同時出現在一個語句中)。然后你可以使用bindValue來敲進你的輸入:

復制代碼 代碼如下:

$statement->bindValue(1, 'Cake');
$statement->bindValue(2, true);

$statement2->bindValue(':name', 'Pie');
$statement2->bindValue(':healthy', false);

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

現在剩下的唯一要做的事情,就是執行我們的語句:

復制代碼 代碼如下:

$statement->execute();
$statement2->execute();
 
//獲取我們的結果:
$cake = $statement->Fetch();
$pie  = $statement2->Fetch();

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

復制代碼 代碼如下:

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

0x09:事務

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

0x10:開啟事務

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

復制代碼 代碼如下:

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

然后你可以繼續執行你的數據庫操作語句,在最后提交事務:

復制代碼 代碼如下:

$db->commit();

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

0x11:其它有用的選項

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

復制代碼 代碼如下:

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

 PDO::ATTR_DEFAULT_FETCH_MODE

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

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

復制代碼 代碼如下:

$query = $db->query('SELECT * FROM `foods`');
$foods = $query->fetchAll(PDO::FETCH_CLASS, 'Food');

PDO::ATTR_ERRMODE

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

PDO::ATTR_TIMEOUT

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产一区玩具在线观看| 欧美高清激情视频| 日韩久久免费视频| 日韩欧亚中文在线| 在线观看精品国产视频| 欧美日韩在线另类| 国产精品久久久久影院日本| 久久九九全国免费精品观看| 国产精品视频一| 2019中文字幕在线免费观看| 久久久久久国产免费| 久久久www成人免费精品张筱雨| 日韩av在线精品| 日本一区二区在线免费播放| 亚洲男子天堂网| 日韩免费视频在线观看| 久久最新资源网| 成人福利视频网| 中文字幕亚洲无线码a| 久久久久日韩精品久久久男男| 欧美怡红院视频一区二区三区| 久久久久久久国产精品| 亚洲电影av在线| 日韩动漫免费观看电视剧高清| 欧美日韩综合视频| 精品欧美国产一区二区三区| 91啪国产在线| 在线看福利67194| 理论片在线不卡免费观看| 欧美精品videos另类日本| 国产中文欧美精品| 久久亚洲精品中文字幕冲田杏梨| 青青草精品毛片| 国产成人精品av在线| 日韩女优在线播放| 在线看日韩av| 国产精品成人一区二区三区吃奶| 亚洲第一福利网站| 91久久嫩草影院一区二区| 日韩欧美视频一区二区三区| 国内精品久久久久久久久| 久久久伊人日本| 97在线免费观看视频| 青草青草久热精品视频在线观看| 色青青草原桃花久久综合| 久久国产精彩视频| 一区二区三区视频在线| 亚洲男人天堂视频| 96国产粉嫩美女| 亚洲最大福利视频| 成人激情视频在线播放| 欧美xxxx综合视频| 国产亚洲一区二区在线| 国产成人综合久久| 亚洲色图校园春色| 91精品国产亚洲| 久国内精品在线| 亚洲国产精品久久久久秋霞不卡| 国产一区二区在线播放| 亚洲欧美激情精品一区二区| 中文在线资源观看视频网站免费不卡| 国产在线视频一区| www日韩中文字幕在线看| 国外成人免费在线播放| 国产香蕉97碰碰久久人人| 欧美成人免费全部| 日韩欧美视频一区二区三区| 91福利视频在线观看| 热草久综合在线| 中文字幕av一区二区| 国产午夜精品视频免费不卡69堂| 2019中文在线观看| 中文字幕一精品亚洲无线一区| 欧美在线www| 羞羞色国产精品| 亚洲人av在线影院| 日韩有码片在线观看| 91亚洲精品一区二区| 久久久国产精品一区| 伊人青青综合网站| 91久久精品日日躁夜夜躁国产| 亚洲国产中文字幕在线观看| 777精品视频| 欧美黑人极品猛少妇色xxxxx| 91精品国产自产在线老师啪| 成人福利在线观看| 5566日本婷婷色中文字幕97| 色综合影院在线| 中文字幕亚洲第一| 亚洲天堂免费观看| 亚洲伊人一本大道中文字幕| 琪琪亚洲精品午夜在线| 精品福利在线视频| 国产精品视频xxxx| 7777精品视频| 26uuu日韩精品一区二区| 日韩国产一区三区| 免费91在线视频| 久久久精品网站| 日本成人精品在线| 久久夜精品va视频免费观看| 亚洲欧美综合另类中字| 热久久免费国产视频| 黑人巨大精品欧美一区免费视频| 欧美另类交人妖| 欧美在线视频一区二区| 成人福利网站在线观看11| 国产综合视频在线观看| 欧美日韩国产二区| 伊人激情综合网| 国产va免费精品高清在线| 亚洲福利在线播放| 欧美激情综合色综合啪啪五月| 国产精品久久在线观看| 亚洲丝袜在线视频| 日韩精品视频在线免费观看| www.xxxx精品| 欧美多人爱爱视频网站| 日韩国产欧美精品一区二区三区| 日本最新高清不卡中文字幕| 亚洲国产欧美一区二区丝袜黑人| 欧美与欧洲交xxxx免费观看| 中文字幕av一区二区| 91在线看www| 欧美精品aaa| 国产精品视频网站| 91在线高清免费观看| 欧美精品激情blacked18| 欧美日韩人人澡狠狠躁视频| 久久九九精品99国产精品| 国产欧美va欧美va香蕉在线| 欧美亚洲午夜视频在线观看| 91精品视频在线看| 青青草原成人在线视频| 日韩电影中文字幕在线观看| 亚洲v日韩v综合v精品v| 一个人看的www久久| 亚洲精品国产精品国自产在线| 国产999精品久久久影片官网| 欧美最猛性xxxxx(亚洲精品)| 日韩电影中文 亚洲精品乱码| 色综合亚洲精品激情狠狠| 性色av一区二区三区| 久久久久亚洲精品成人网小说| 亚洲美女av网站| 91精品在线国产| 久久亚洲成人精品| 九九精品视频在线观看| 欧美亚洲国产日韩2020| 欧美日韩日本国产| 91亚洲精品一区| 亚洲精品按摩视频| 91av网站在线播放| 成人在线精品视频| 欧美丰满少妇xxxxx| 91香蕉亚洲精品| 国产午夜精品视频| 日韩成人在线视频| 日韩精品视频中文在线观看| 欧美洲成人男女午夜视频| 国产精品旅馆在线| 亚洲人成网站在线播| 欧美影院在线播放| 国产精品日韩欧美综合|