新聞中心
在PHP應(yīng)用程序中,要操作數(shù)據(jù)庫(kù)就必須掌握相應(yīng)的數(shù)據(jù)庫(kù)操作知識(shí),PDO(PHP Data Objects)就是PHP中連接數(shù)據(jù)庫(kù)的擴(kuò)展程序之一,它為程序員提供了一個(gè)良好的API,可以更方便地與數(shù)據(jù)庫(kù)進(jìn)行交互。本篇文章將介紹如何使用PDO獲取MySQL數(shù)據(jù)庫(kù)中的數(shù)據(jù)。

一、連接數(shù)據(jù)庫(kù)
在使用PDO獲取數(shù)據(jù)之前,首先需要通過PDO連接到MySQL數(shù)據(jù)庫(kù)。連接MySQL數(shù)據(jù)庫(kù)的基本語(yǔ)法如下:
“`
$dbname = ‘test’;
$dbuser = ‘root’;
$dbpassword = ‘root’;
$dbhost = ‘localhost’;
$dsn = “mysql:host={$dbhost};dbname={$dbname}”;
$dbh = new PDO($dsn, $dbuser, $dbpassword);
“`
這里我們定義了四個(gè)變量,分別是數(shù)據(jù)庫(kù)名稱、用戶名、密碼和數(shù)據(jù)庫(kù)主機(jī)地址。使用這些變量定義了一個(gè)DSN(Data Source Name),然后使用PDO的構(gòu)造函數(shù)建立與數(shù)據(jù)庫(kù)的連接。如果連接失敗,PDO將會(huì)拋出一個(gè)PDOException異常,我們可以使用try-catch語(yǔ)句捕獲這個(gè)異常并進(jìn)行相應(yīng)的處理。
二、查詢數(shù)據(jù)
連接到數(shù)據(jù)庫(kù)之后,開始查詢數(shù)據(jù)。PDO提供了三個(gè)查詢方法,分別是query()、prepare()和exec()。其中query()方法用于執(zhí)行一條SQL查詢語(yǔ)句,它的返回值是一個(gè)PDOStatement對(duì)象,該對(duì)象包含了查詢結(jié)果的所有數(shù)據(jù)。prepare()方法同樣用于執(zhí)行SQL語(yǔ)句,但它與query()方法不同的是它返回一個(gè)PDOStatement對(duì)象,該對(duì)象封裝了查詢的模板,我們可以通過模板填充外部數(shù)據(jù)來執(zhí)行查詢。而exec()方法用于執(zhí)行SQL語(yǔ)句,但是它只返回受影響的行數(shù),對(duì)于查詢語(yǔ)句來說就沒什么用了。
對(duì)于查詢數(shù)據(jù),我們通常使用query()方法,如下所示:
“`
$sql = “SELECT * FROM users”;
$stmt = $dbh->query($sql);
“`
在這里,我們定義了一條查詢語(yǔ)句,它用SELECT語(yǔ)句獲取users表中的所有數(shù)據(jù)。然后使用PDO的query()方法執(zhí)行這條語(yǔ)句,并返回一個(gè)PDOStatement對(duì)象,我們將其保存在一個(gè)變量中。
三、獲取數(shù)據(jù)
接下來我們需要從PDOStatement對(duì)象中獲取數(shù)據(jù)。PDOStatement對(duì)象提供了三種獲取數(shù)據(jù)的方法,分別是fetch()、fetchAll()和fetchColumn()。其中fetch()方法用于獲取查詢結(jié)果的一行數(shù)據(jù),它可以接受兩個(gè)參數(shù):之一個(gè)參數(shù)用于設(shè)置返回?cái)?shù)據(jù)的格式,可以是PDO::FETCH_ASSOC、PDO::FETCH_OBJ等;第二個(gè)參數(shù)用于設(shè)置獲取數(shù)據(jù)的方式,可以是正數(shù)、負(fù)數(shù)或者零,分別代表不同的方式。fetchAll()方法與fetch()方法類似,不同的是它可以一次性獲取所有查詢結(jié)果的數(shù)據(jù),返回值是一個(gè)二維數(shù)組。而fetchColumn()方法用于獲取查詢結(jié)果的指定列,返回指定列數(shù)據(jù)的之一行。
對(duì)于上面的查詢結(jié)果,我們可以使用fetch()方法獲取一行數(shù)據(jù),如下所示:
“`
while ($row = $stmt->fetch(PDO::FETCH_ASSOC)) {
echo $row[‘id’] . ‘ – ‘ . $row[‘name’] . ‘
‘;
}
“`
在這里,我們使用while循環(huán)遍歷PDOStatement對(duì)象中的數(shù)據(jù),依次使用fetch()方法獲取一行數(shù)據(jù)并輸出。由于查詢結(jié)果是一個(gè)關(guān)聯(lián)數(shù)組,我們可以通過數(shù)組下標(biāo)獲取相應(yīng)的數(shù)據(jù)值。
如果希望一次性獲取所有查詢結(jié)果的數(shù)據(jù),可以使用fetchAll()方法,如下所示:
“`
$data = $stmt->fetchAll(PDO::FETCH_ASSOC);
print_r($data);
“`
在這里,我們使用fetchAll()方法獲取所有查詢結(jié)果的數(shù)據(jù),并將數(shù)據(jù)保存在一個(gè)變量中。由于返回結(jié)果是一個(gè)二維數(shù)組,我們可以通過print_r()函數(shù)將結(jié)果輸出。
四、
本篇文章介紹了如何使用PDO獲取MySQL數(shù)據(jù)庫(kù)中的數(shù)據(jù)。首先需要連接數(shù)據(jù)庫(kù),然后使用query()方法執(zhí)行查詢語(yǔ)句并返回一個(gè)PDOStatement對(duì)象,最后使用fetch()或者fetchAll()方法獲取查詢結(jié)果的數(shù)據(jù)。使用PDO可以更方便地與數(shù)據(jù)庫(kù)進(jìn)行交互,并提供了良好的安全性和可移植性。在運(yùn)用PDO進(jìn)行數(shù)據(jù)操作時(shí),我們可以靈活應(yīng)用上述查詢數(shù)據(jù)的方法,對(duì)于我們的數(shù)據(jù)獲取與處理能力來說具有很好的輔助與提升作用。
相關(guān)問題拓展閱讀:
- PHP使用pdo連接access數(shù)據(jù)庫(kù)并循環(huán)顯示數(shù)據(jù)操作示例
- PHP采用pdo方式訪問數(shù)據(jù)庫(kù)時(shí),exec方法和prepare方法有什么區(qū)別
PHP使用pdo連接access數(shù)據(jù)庫(kù)并循環(huán)顯示數(shù)據(jù)操作示例
本文實(shí)例講述了PHP使用pdo連接access數(shù)據(jù)庫(kù)并循環(huán)顯示數(shù)據(jù)操作。分享給大家供大家參考,具體如下:
PDO連接與查詢:
try
{
$conn
=
new
PDO(“odbc:driver={microsoft
access
driver
(*.mdb)};
dbq=”.realpath(“MyDatabase.mdb”))
or
die(“鏈接錯(cuò)誤!”);
//echo
“鏈接成功!”;
}
catch(PDOException
$e){
echo
$e->getMessage();
}
$sql
=
“select
*
from
users”;
1.
foreach()方法
foreach
($conn->query($sql)
as
$row)
{
$row;
$row;
$row;
}
2.
while()方法
$rs
=
$conn->query($sql);
$rs->setFetchMode(PDO::FETCH_NUM);
while($row=$rs->fetch()){
$row;
$row;
$row;
}
php使用PDO抽象層獲取查詢結(jié)果,主要有三種方式:
(1)PDO::query()查詢。
看下面這段php代碼:
query(‘select
*
from
user’);
$res->setFetchMode(PDO::FETCH_NUM);
//數(shù)字索引方式
while
($row
=
$res->fetch()){
print_r($row);
}
?>
(2)PDO->exec()處理sql
exec()處理sql
$db->setAttribute(PDO::ATTR_ERRMODE,
PDO::ERRMODE_EXCEPTION);
$res
=
$db->exec(“insert
into
user(id,name)
values(”,’php點(diǎn)點(diǎn)通’)”);
echo
$res;
?>
(3)PDO::prepare()預(yù)處理執(zhí)行查詢
prepare(“select
*
from
user”);
$res->execute();
while
($row
=
$res->fetchAll())
{
print_r($row);
}
?>
setAttribute()
方法是設(shè)置屬性,常用參數(shù)如下:
PDO::CASE_LOWER
—
強(qiáng)制列名是小寫
PDO::CASE_NATURAL
—
列名按照原始的方式
PDO::CASE_UPPER
—
強(qiáng)制列名為大寫
setFetchMode方法來設(shè)置獲取結(jié)果集的返回值的類型,常用參數(shù)如下:
PDO::FETCH_ASSOC
—
關(guān)聯(lián)數(shù)組形式
PDO::FETCH_NUM
—
數(shù)字索引數(shù)組形式
PDO::FETCH_BOTH
—
兩者數(shù)組形式都有,這是默認(rèn)的
PDO::FETCH_OBJ
—
按照對(duì)象的形式,類似于以前的
mysql_fetch_object()
對(duì)上面總結(jié)如下:
查詢操作主要是PDO::query()、PDO::exec()、PDO::prepare()。
PDO->query()
—
處團(tuán)返廳理一條SQL語(yǔ)句,并返回一個(gè)“PDOStatement”
PDO->exec()
—
處理一條SQL語(yǔ)句,并返回所影響的條目數(shù)
PDO::prepare()主要是預(yù)處理操作,需要通過$rs->execute()來執(zhí)行預(yù)處理里面的SQL語(yǔ)句
最后介紹兩個(gè)常用的函數(shù):
(1)fetchColumn()獲取指世螞定記錄里一個(gè)字段結(jié)果,默認(rèn)是之一個(gè)字段!
query(‘select
*
from
user’);
//獲取指定記錄里第二個(gè)字段結(jié)果
$col
=
$res->fetchColumn(1);
echo
$col;
?>
(2)fetchAll(),從一個(gè)結(jié)果集中獲取數(shù)據(jù),然后存放在關(guān)聯(lián)數(shù)組中
query(‘select
*
from
user’);
$res_arr
=$res->fetchAll();
print_r($res_arr);
?>
更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《PHP基于pdo操作數(shù)據(jù)庫(kù)技巧總結(jié)》、《php+Oracle數(shù)據(jù)庫(kù)程序設(shè)計(jì)技巧總結(jié)》、《PHP+MongoDB數(shù)據(jù)庫(kù)操作技巧大全》、《php面向?qū)ο蟪绦蛟O(shè)計(jì)入門教程》、《php字符串(string)用法總結(jié)》、《php+mysql數(shù)據(jù)庫(kù)操作入門教程》及《php常見數(shù)據(jù)庫(kù)操作技巧匯總》
希望本文所述對(duì)大家PHP程序設(shè)計(jì)有所幫助。
您可能感興趣的文章:PHP使用PDO連接ACCESS數(shù)據(jù)庫(kù)PHP數(shù)據(jù)庫(kù)鏈接類(PDO+Access)實(shí)例分享php中mysql連接方式PDO使用詳解關(guān)于php連接mssql:pdo
odbc
sql
serverPhp中用PDO查詢Mysql來避免SQL注入風(fēng)險(xiǎn)的方法php中在PDO中使用事務(wù)(Transaction)全新的PDO數(shù)據(jù)庫(kù)操作類php版(僅適用Mysql)php使用pdo連接并查詢sql數(shù)據(jù)庫(kù)的方法php使用pdo連接mssql
PHP采用pdo方式訪問數(shù)據(jù)庫(kù)時(shí),exec方法和prepare方法有什么區(qū)別
區(qū)別是:
PHP采用pdo方式訪問數(shù)據(jù)庫(kù)時(shí),您不必再使用再為它們封裝數(shù)據(jù)庫(kù)操作類,只需要使用PDO接口中的方法就可以對(duì)各種數(shù)據(jù)庫(kù)進(jìn)行操作。
關(guān)于php pdo獲取數(shù)據(jù)庫(kù)的介紹到此就結(jié)束了,不知道你從中找到你需要的信息了嗎 ?如果你還想了解更多這方面的信息,記得收藏關(guān)注本站。
創(chuàng)新互聯(lián)服務(wù)器托管擁有成都T3+級(jí)標(biāo)準(zhǔn)機(jī)房資源,具備完善的安防設(shè)施、三線及BGP網(wǎng)絡(luò)接入帶寬達(dá)10T,機(jī)柜接入千兆交換機(jī),能夠有效保證服務(wù)器托管業(yè)務(wù)安全、可靠、穩(wěn)定、高效運(yùn)行;創(chuàng)新互聯(lián)專注于成都服務(wù)器托管租用十余年,得到成都等地區(qū)行業(yè)客戶的一致認(rèn)可。
新聞名稱:PHPPDO學(xué)習(xí)筆記:獲取數(shù)據(jù)庫(kù)數(shù)據(jù)(phppdo獲取數(shù)據(jù)庫(kù))
新聞來源:http://m.fisionsoft.com.cn/article/cosghsh.html


咨詢
建站咨詢
