亚洲视频二区_亚洲欧洲日本天天堂在线观看_日韩一区二区在线观看_中文字幕不卡一区

公告:魔扣目錄網(wǎng)為廣大站長(zhǎng)提供免費(fèi)收錄網(wǎng)站服務(wù),提交前請(qǐng)做好本站友鏈:【 網(wǎng)站目錄:http://www.430618.com 】, 免友鏈快審服務(wù)(50元/站),

點(diǎn)擊這里在線咨詢客服
新站提交
  • 網(wǎng)站:51998
  • 待審:31
  • 小程序:12
  • 文章:1030137
  • 會(huì)員:747

PHP PDO 簡(jiǎn)單教程

 

php 5.5 版本之前,我們有用于訪問(wèn) MySQL 數(shù)據(jù)庫(kù)的 mysql_ 命令,但由于安全性不足,它們最終被棄用。mysql_ 的棄用帶來(lái)了訪問(wèn)數(shù)據(jù)庫(kù)的兩種主要方法:mysqli 和 PDO 庫(kù)。

-- Rishabh Kandari(作者)

大約 80% 的 Web 應(yīng)用程序由 PHP 提供支持。類似地,SQL 也是如此。PHP 5.5 版本之前,我們有用于訪問(wèn) MySQL 數(shù)據(jù)庫(kù)的 mysql_ 命令,但由于安全性不足,它們最終被棄用。

棄用這件事是發(fā)生在 2013 年的 PHP 5.5 上,我寫這篇文章的時(shí)間是 2018 年,PHP 版本為 7.2。mysql_ 的棄用帶來(lái)了訪問(wèn)數(shù)據(jù)庫(kù)的兩種主要方法:mysqli 和 PDO 庫(kù)。

雖然 mysqli 庫(kù)是官方指定的,但由于 mysqli 只能支持 mysql 數(shù)據(jù)庫(kù),而 PDO 可以支持 12 種不同類型的數(shù)據(jù)庫(kù)驅(qū)動(dòng)程序,因此 PDO 獲得了更多的贊譽(yù)。此外,PDO 還有其它一些特性,使其成為大多數(shù)開發(fā)人員的更好選擇。你可以在下表中看到一些特性比較:

PDOMySQLi數(shù)據(jù)庫(kù)支持12 種驅(qū)動(dòng)只有 MySQL范例OOP過(guò)程 + OOP預(yù)處理語(yǔ)句(客戶端側(cè))YesNo1命名參數(shù)YesNo

現(xiàn)在我想對(duì)于大多數(shù)開發(fā)人員來(lái)說(shuō),PDO 是首選的原因已經(jīng)很清楚了。所以讓我們深入研究它,并希望在本文中盡量涵蓋關(guān)于 PDO 你需要的了解的。

連接

第一步是連接到數(shù)據(jù)庫(kù),由于 PDO 是完全面向?qū)ο蟮模晕覀儗⑹褂?PDO 類的實(shí)例。

我們要做的第一件事是定義主機(jī)、數(shù)據(jù)庫(kù)名稱、用戶名、密碼和數(shù)據(jù)庫(kù)字符集。

$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 變量只是一個(gè)保存數(shù)據(jù)庫(kù)信息的變量。對(duì)于一些在外部服務(wù)器上運(yùn)行 MySQL 的人,你還可以通過(guò)提供一個(gè) port=$port_number 來(lái)調(diào)整端口號(hào)。

最后,你可以創(chuàng)建一個(gè) PDO 類的實(shí)例,我使用了 $conn 變量,并提供了 $dsn、$user、$pass 參數(shù)。如果你遵循這些步驟,你現(xiàn)在應(yīng)該有一個(gè)名為 $conn 的對(duì)象,它是 PDO 連接類的一個(gè)實(shí)例。現(xiàn)在是時(shí)候進(jìn)入數(shù)據(jù)庫(kù)并運(yùn)行一些查詢。

一個(gè)簡(jiǎn)單的 SQL 查詢

現(xiàn)在讓我們運(yùn)行一個(gè)簡(jiǎ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)行查詢的最簡(jiǎn)單形式。我們首先創(chuàng)建了一個(gè)名為 tis(TheITStuff 的縮寫 )的變量,然后你可以看到我們使用了創(chuàng)建的 $conn 對(duì)象中的查詢函數(shù)。

然后我們運(yùn)行一個(gè) while 循環(huán)并創(chuàng)建了一個(gè) $row 變量來(lái)從 $tis 對(duì)象中獲取內(nèi)容,最后通過(guò)調(diào)用列名來(lái)顯示每一行。

很簡(jiǎn)單,不是嗎?現(xiàn)在讓我們來(lái)看看預(yù)處理語(yǔ)句。

預(yù)處理語(yǔ)句

預(yù)處理語(yǔ)句是人們開始使用 PDO 的主要原因之一,因?yàn)樗峁┝丝梢宰柚?SQL 注入的語(yǔ)句。

有兩種基本方法可供使用,你可以使用位置參數(shù)或命名參數(shù)。

位置參數(shù)

讓我們看一個(gè)使用位置參數(shù)的查詢示例。

$tis = $conn->prepare("INSERT INTO STUDENTS(name, age) values(?, ?)");
$tis->bindValue(1,'mike');
$tis->bindValue(2,22);
$tis->execute();

在上面的例子中,我們放置了兩個(gè)問(wèn)號(hào),然后使用 bindValue() 函數(shù)將值映射到查詢中。這些值綁定到語(yǔ)句問(wèn)號(hào)中的位置。

我還可以使用變量而不是直接提供值,通過(guò)使用 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ù)處理語(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 作為占位符,然后將變量映射到它們。冒號(hào)在參數(shù)之前使用,讓 PDO 知道該位置是一個(gè)變量,這非常重要。

你也可以類似地使用 bindValue() 來(lái)使用命名參數(shù)直接映射值。

獲取數(shù)據(jù)

PDO 在獲取數(shù)據(jù)時(shí)非常豐富,它實(shí)際上提供了許多格式來(lái)從數(shù)據(jù)庫(kù)中獲取數(shù)據(jù)。

你可以使用 PDO::FETCH_ASSOC 來(lái)獲取關(guān)聯(lián)數(shù)組,PDO::FETCH_NUM 來(lái)獲取數(shù)字?jǐn)?shù)組,使用 PDO::FETCH_OBJ 來(lái)獲取對(duì)象數(shù)組。

$tis = $conn->prepare("SELECT * FROM STUDENTS");
$tis->execute();
$result = $tis->fetchAll(PDO::FETCH_ASSOC);

你可以看到我使用了 fetchAll,因?yàn)槲蚁胍衅ヅ涞挠涗洝H绻恍枰恍校憧梢院?jiǎn)單地使用 fetch。

現(xiàn)在我們已經(jīng)獲取了數(shù)據(jù),現(xiàn)在是時(shí)候循環(huán)它了,這非常簡(jiǎn)單。

foreach ($result as $lnu){
 echo $lnu['name'];
 echo $lnu['age']."<br>";
}

你可以看到,因?yàn)槲艺?qǐng)求了關(guān)聯(lián)數(shù)組,所以我正在按名稱訪問(wèn)各個(gè)成員。

雖然在定義希望如何傳輸遞數(shù)據(jù)方面沒有要求,但在定義 $conn 變量本身時(shí),實(shí)際上可以將其設(shè)置為默認(rèn)值。

你需要做的就是創(chuàng)建一個(gè) $options 數(shù)組,你可以在其中放入所有默認(rèn)配置,只需在 $conn 變量中傳遞數(shù)組即可。

$options = [
 PDO::ATTR_DEFAULT_FETCH_MODE => PDO::FETCH_ASSOC,
];
$conn = new PDO($dsn, $user, $pass, $options);

這是一個(gè)非常簡(jiǎn)短和快速的 PDO 介紹,我們很快就會(huì)制作一個(gè)高級(jí)教程。如果你在理解本教程的任何部分時(shí)遇到任何困難,請(qǐng)?jiān)谠u(píng)論部分告訴我,我會(huì)在那你為你解答。


via: http://www.theitstuff.com/easiest-pdo-tutorial-basics

作者: Rishabh Kandari 選題: lujun9972 譯者: MjSeven 校對(duì): wxy

本文由 LCTT 原創(chuàng)編譯, linux中國(guó) 榮譽(yù)推出

分享到:
標(biāo)簽:PHP PDO
用戶無(wú)頭像

網(wǎng)友整理

注冊(cè)時(shí)間:

網(wǎng)站:5 個(gè)   小程序:0 個(gè)  文章:12 篇

  • 51998

    網(wǎng)站

  • 12

    小程序

  • 1030137

    文章

  • 747

    會(huì)員

趕快注冊(cè)賬號(hào),推廣您的網(wǎng)站吧!
最新入駐小程序

數(shù)獨(dú)大挑戰(zhàn)2018-06-03

數(shù)獨(dú)一種數(shù)學(xué)游戲,玩家需要根據(jù)9

答題星2018-06-03

您可以通過(guò)答題星輕松地創(chuàng)建試卷

全階人生考試2018-06-03

各種考試題,題庫(kù),初中,高中,大學(xué)四六

運(yùn)動(dòng)步數(shù)有氧達(dá)人2018-06-03

記錄運(yùn)動(dòng)步數(shù),積累氧氣值。還可偷

每日養(yǎng)生app2018-06-03

每日養(yǎng)生,天天健康

體育訓(xùn)練成績(jī)?cè)u(píng)定2018-06-03

通用課目體育訓(xùn)練成績(jī)?cè)u(píng)定