小編給大家分享一下PHP中PDO的示例分析,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
站在用戶的角度思考問題,與客戶深入溝通,找到乳源網(wǎng)站設(shè)計與乳源網(wǎng)站推廣的解決方案,憑借多年的經(jīng)驗(yàn),讓設(shè)計與互聯(lián)網(wǎng)技術(shù)結(jié)合,創(chuàng)造個性化、用戶體驗(yàn)好的作品,建站類型包括:成都網(wǎng)站設(shè)計、網(wǎng)站建設(shè)、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣、主機(jī)域名、網(wǎng)站空間、企業(yè)郵箱。業(yè)務(wù)覆蓋乳源地區(qū)。大約 80% 的 Web 應(yīng)用程序由 PHP 提供支持。類似地,SQL 也是如此。PHP 5.5 版本之前,我們有用于訪問 MySQL 數(shù)據(jù)庫的 mysql_ 命令,但由于安全性不足,它們最終被棄用。
棄用這件事是發(fā)生在 2013 年的 PHP 5.5 上,我寫這篇文章的時間是 2018 年,PHP 版本為 7.2。mysql_ 的棄用帶來了訪問數(shù)據(jù)庫的兩種主要方法:mysqli 和 PDO 庫。
雖然 mysqli 庫是官方指定的,但由于 mysqli 只能支持 mysql 數(shù)據(jù)庫,而 PDO 可以支持 12 種不同類型的數(shù)據(jù)庫驅(qū)動程序,因此 PDO 獲得了更多的贊譽(yù)。此外,PDO 還有其它一些特性,使其成為大多數(shù)開發(fā)人員的更好選擇。你可以在下表中看到一些特性比較:
PDO | MySQLi | |
---|---|---|
數(shù)據(jù)庫支持 | 12 種驅(qū)動 | 只有 MySQL |
范例 | OOP | 過程 + OOP |
預(yù)處理語句(客戶端側(cè)) | Yes | No |
1命名參數(shù) | Yes | No |
現(xiàn)在我想對于大多數(shù)開發(fā)人員來說,PDO 是選的原因已經(jīng)很清楚了。所以讓我們深入研究它,并希望在本文中盡量涵蓋關(guān)于 PDO 你需要的了解的。
連接
第一步是連接到數(shù)據(jù)庫,由于 PDO 是完全面向?qū)ο蟮?,所以我們將使?PDO 類的實(shí)例。
我們要做的第一件事是定義主機(jī)、數(shù)據(jù)庫名稱、用戶名、密碼和數(shù)據(jù)庫字符集。
$host = 'localhost'; $db = 'theitstuff'; $user = 'root'; $pass = 'root'; $charset = 'utf8mb4'; $dsn = "mysql:host=$host;dbname=$db;charset=$charset"; $conn = new PDO($dsn, $user, $pass);
之后,正如你在上面的代碼中看到的,我們創(chuàng)建了 DSN 變量,DSN 變量只是一個保存數(shù)據(jù)庫信息的變量。對于一些在外部服務(wù)器上運(yùn)行 MySQL 的人,你還可以通過提供一個 port=$port_number 來調(diào)整端口號。
最后,你可以創(chuàng)建一個 PDO 類的實(shí)例,我使用了 $conn 變量,并提供了 $dsn、$user、$pass 參數(shù)。如果你遵循這些步驟,你現(xiàn)在應(yīng)該有一個名為 $conn 的對象,它是 PDO 連接類的一個實(shí)例。現(xiàn)在是時候進(jìn)入數(shù)據(jù)庫并運(yùn)行一些查詢。
一個簡單的 SQL 查詢
現(xiàn)在讓我們運(yùn)行一個簡單的 SQL 查詢。
$tis = $conn->query('SELECT name, age FROM students'); while ($row = $tis->fetch()) { echo $row['name']."\t"; echo $row['age']; echo "<br>"; }
這是使用 PDO 運(yùn)行查詢的最簡單形式。我們首先創(chuàng)建了一個名為 tis(TheITStuff 的縮寫 )的變量,然后你可以看到我們使用了創(chuàng)建的 $conn 對象中的查詢函數(shù)。
然后我們運(yùn)行一個 while 循環(huán)并創(chuàng)建了一個 $row 變量來從 $tis 對象中獲取內(nèi)容,最后通過調(diào)用列名來顯示每一行。
很簡單,不是嗎?現(xiàn)在讓我們來看看預(yù)處理語句。
預(yù)處理語句
預(yù)處理語句是人們開始使用 PDO 的主要原因之一,因?yàn)樗峁┝丝梢宰柚?SQL 注入的語句。
有兩種基本方法可供使用,你可以使用位置參數(shù)或命名參數(shù)。
位置參數(shù)
讓我們看一個使用位置參數(shù)的查詢示例。
$tis = $conn->prepare("INSERT INTO STUDENTS(name, age) values(?, ?)"); $tis->bindValue(1,'mike'); $tis->bindValue(2,22); $tis->execute();
在上面的例子中,我們放置了兩個問號,然后使用 bindValue() 函數(shù)將值映射到查詢中。這些值綁定到語句問號中的位置。
我還可以使用變量而不是直接提供值,通過使用 bindParam() 函數(shù)相同例子如下:
$name='Rishabh'; $age=20; $tis = $conn->prepare("INSERT INTO STUDENTS(name, age) values(?, ?)"); $tis->bindParam(1,$name); $tis->bindParam(2,$age); $tis->execute();
命名參數(shù)
命名參數(shù)也是預(yù)處理語句,它將值/變量映射到查詢中的命名位置。由于沒有位置綁定,因此在多次使用相同變量的查詢中非常有效。
$name='Rishabh'; $age=20; $tis = $conn->prepare("INSERT INTO STUDENTS(name, age) values(:name, :age)"); $tis->bindParam(':name', $name); $tis->bindParam(':age', $age); $tis->execute();
你可以注意到,的變化是我使用 :name 和 :age 作為占位符,然后將變量映射到它們。冒號在參數(shù)之前使用,讓 PDO 知道該位置是一個變量,這非常重要。
你也可以類似地使用 bindValue() 來使用命名參數(shù)直接映射值。
獲取數(shù)據(jù)
PDO 在獲取數(shù)據(jù)時非常豐富,它實(shí)際上提供了許多格式來從數(shù)據(jù)庫中獲取數(shù)據(jù)。
你可以使用 PDO::FETCH_ASSOC 來獲取關(guān)聯(lián)數(shù)組,PDO::FETCH_NUM 來獲取數(shù)字?jǐn)?shù)組,使用 PDO::FETCH_OBJ 來獲取對象數(shù)組。
$tis = $conn->prepare("SELECT * FROM STUDENTS"); $tis->execute(); $result = $tis->fetchAll(PDO::FETCH_ASSOC);
你可以看到我使用了 fetchAll,因?yàn)槲蚁胍衅ヅ涞挠涗?。如果只需要一行,你可以簡單地使?fetch。
現(xiàn)在我們已經(jīng)獲取了數(shù)據(jù),現(xiàn)在是時候循環(huán)它了,這非常簡單。
foreach ($result as $lnu){ echo $lnu['name']; echo $lnu['age']."<br>"; }
你可以看到,因?yàn)槲艺埱罅岁P(guān)聯(lián)數(shù)組,所以我正在按名稱訪問各個成員。
雖然在定義希望如何傳輸遞數(shù)據(jù)方面沒有要求,但在定義 $conn 變量本身時,實(shí)際上可以將其設(shè)置為默認(rèn)值。
你需要做的就是創(chuàng)建一個 $options 數(shù)組,你可以在其中放入所有默認(rèn)配置,只需在 $conn 變量中傳遞數(shù)組即可。
$options = [ PDO::ATTR_DEFAULT_FETCH_MODE => PDO::FETCH_ASSOC, ]; $conn = new PDO($dsn, $user, $pass, $options);
這是一個非常簡短和快速的 PDO 介紹,我們很快就會制作一個高級教程。如果你在理解本教程的任何部分時遇到任何困難,請?jiān)谠u論部分告訴我,我會在那你為你解答。
以上是“PHP中PDO的示例分析”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!
新聞名稱:PHP中PDO的示例分析-創(chuàng)新互聯(lián)
文章出自:http://aaarwkj.com/article4/dpjiie.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站維護(hù)、自適應(yīng)網(wǎng)站、網(wǎng)頁設(shè)計公司、Google、外貿(mào)建站、電子商務(wù)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容