首頁 >後端開發 >php教程 >PHP使用pdo連接access資料庫並循環顯示資料操作

PHP使用pdo連接access資料庫並循環顯示資料操作

不言
不言原創
2018-06-05 16:38:341863瀏覽

這篇文章主要介紹了PHP使用pdo連接access資料庫並循環顯示資料操作,結合實例形式較為詳細的分析了php使用pdo進行access資料庫連接、查詢、執行sql語句、預處理等相關操作技巧與注意事項,需要的朋友可以參考下

本文實例講述了PHP使用pdo連接access資料庫並循環顯示資料操作。分享給大家供大家參考,具體如下:

PDO連線與查詢:

#
try {
$conn = new PDO("odbc:driver={microsoft access driver (*.mdb)};
       dbq=".realpath("MyDatabase.mdb"))
       or die("链接错误!");
//echo "链接成功!";
}
catch(PDOException $e){
  echo $e->getMessage();
}
$sql = "select * from users";

1. foreach()方法

foreach ($conn->query($sql) as $row) {
$row["UserID"];
$row["UserName"];
$row["UserPassword"];
}

2. while()方法

$rs = $conn->query($sql);
$rs->setFetchMode(PDO::FETCH_NUM);
while($row=$rs->fetch()){
$row[0];
$row[1];
$row[2];
}

php使用PDO抽象層取得查詢結果,主要有三種方式:

(1)PDO::query()查詢。

看下面這段php程式碼:

<?php
//PDO::query()查询
$res = $db->query(&#39;select * from user&#39;);
$res->setFetchMode(PDO::FETCH_NUM); //数字索引方式
while ($row = $res->fetch()){
print_r($row);
}
?>

#(2)PDO->exec()處理sql

<?php
//PDO->exec()处理sql
$db->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
$res = $db->exec("insert into user(id,name) values(&#39;&#39;,&#39;php点点通&#39;)");
echo $res;
?>

(3)PDO::prepare()預處理執行查詢

<?php
//PDO::prepare()预处理执行查询
$res = $db->prepare("select * from user");
$res->execute();
while ($row = $res->fetchAll()) {
print_r($row);
}
?>

setAttribute() 方法是設定屬性,常用參數如下:

PDO::CASE_LOWER -- 強制列名是小寫
PDO::CASE_NATURAL -- 列名依照原始的方式
PDO::CASE_UPPER -- 強制列名為大寫

#setFetchMode方法來設定取得結果集的回傳值的類型,常用參數如下:

PDO::FETCH_ASSOC -- 關聯陣列形式
PDO::FETCH_NUM -- 數字索引數組形式
PDO::FETCH_BOTH -- 兩者數組形式都有,這是預設的
PDO::FETCH_OBJ -- 按照物件的形式,類似先前的mysql_fetch_object()

對上面總結如下:

查詢操作主要是PDO::query()PDO: :exec()PDO::prepare()

PDO->query() — 處理一條SQL語句,並傳回一個「PDOStatement」
PDO->exec() — 處理一條SQL語句,並且傳回所影響的條目數
PDO::prepare()主要是預處理操作,需要透過$rs->execute()來執行預處理裡面的SQL語句

最後介紹兩個常用的函數:

(1)fetchColumn()取得指定記錄裡一個欄位結果,預設是第一個字段!

<?php
$res = $db->query(&#39;select * from user&#39;);
//获取指定记录里第二个字段结果
$col = $res->fetchColumn(1);
echo $col;
?>

(2)fetchAll(),從一個結果集中取得數據,然後存放在關聯數組中

<?php
$res = $db->query(&#39;select * from user&#39;);
$res_arr =$res->fetchAll();
print_r($res_arr);
?>

相關推薦:

#PHP ADODB產生HTML表格函數rs2html功能【附錯誤處理函數用法】

PHP使用正規表示式實作過濾非法字串功能範例

以上是PHP使用pdo連接access資料庫並循環顯示資料操作的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn