fetch()方法
fetch()方法用於取得結果集的下一行,語法如下:
mixed PDOStatement::fetch([int fetch_style][,int cursor_orientation[,int cursor_offset]]])
參數fetch_style控制結果集的回傳方式
PDO::FETCH_ASSOC -- 關聯陣列形式
#PDO::FETCH_NUM -- 數字索引數組形式
PDO::FETCH_BOTH -- 兩者數組形式都有,這是預設的
##PDO:: FETCH_OBJ -- 依照物件的形式,類似先前的mysql_fetch_object()
#PDO::FETCH_BOUND--以布林值的形式傳回結果,同時取得的列值賦給bindParam()方法中的指定變數。
PDO::FETCH_LAZY--以關聯數組、數字索引數組和物件3種形式傳回結果
cursor_orientation:PDOStatement物件的一個捲動遊標,可用來取得指定的一行。
在PDO中透過預處理語句prepare ()和execute()執行SQL查詢語句,並且應用while()語句和fetch()方法完成資料的循環輸出
$dbms='mysql';//数据库类型 $dbName='admin';//使用的数据库 $user='root';//数据库连接用户名 $pwd='password';//数据库连接密码 $host='localhost';//数据库主机名 $dsn="$dbms:host=$host;port=3306;dbname=$dbName"; try{ $pdo=new PDO($dsn,$user,$pwd);//初始化一个PDO对象,就是创建了数据库连接对象$pdo $query="select * from user";//需要执行的sql语句 $res=$pdo->prepare($query);//准备查询语句 $res->execute(); while($result=$res->fetch(PDO::FETCH_ASSOC)){ echo $result['id']." ".$result['username']." ".$result['password'].'<br>'; } }catch(Exception $e){ die("Error!:".$e->getMessage().'<br>'); }
##運行結果為: 1
107lab e10adc3949ba59abbe56e057f20f883e
4 admin 123456
5 admin 123456
fetchAll()方法
fetchAll()方法用於取得結果集中的所有行,其傳回值是一個包含結果集中所有資料的二進位數組。語法如下:# 参数说明: fetch_style:控制结果集中数据的显示方式。 column_index:
字段的索引。 例如: 运行结果为: 此时可以通过foreach来遍历这个二维数组 运行结果为: fetchColumn()方法 fetchColumn()方法获取结果集中下一行指定列的值,语法如下: string
PDOStatement::fetchColumn([int column_number]) 可选参数column_number设置行中列的索引值,该值从0开始。如果省略该参数则将从第1列开始取值 例如: 通过fetchColumn()方法获取结果集中下一行中指定列的值。(或第一列id的值) 运行结果为: 以上就是PDO中获取结果集的内容,更多相关内容请关注PHP中文网(www.php.cn)!array
PDOStatement::fetchAll([int fetch_style[,int column_index]])
$dbms='mysql';//数据库类型
$dbName='admin';//使用的数据库
$user='root';//数据库连接用户名
$pwd='password';//数据库连接密码
$host='localhost';//数据库主机名
$dsn="$dbms:host=$host;port=3306;dbname=$dbName";
try{
$pdo=new PDO($dsn,$user,$pwd);//初始化一个PDO对象,就是创建了数据库连接对象$pdo
$query="select * from user";//需要执行的sql语句
$res=$pdo->prepare($query);//准备查询语句
$res->execute();
$result=$res->fetchAll(PDO::FETCH_ASSOC);
print_r($result);
}catch(Exception $e){
die("Error!:".$e->getMessage().'<br>');
}
Array
(
[0] => Array
(
[id] => 1
[username] => 107lab
[password] => e10adc3949ba59abbe56e057f20f883e
)
[1] => Array
(
[id] => 4
[username] => admin
[password] => 123456
)
[2] => Array
(
[id] => 5
[username] => admin
[password] => 123456
)
)
foreach($result as $val){
echo $val['username'].'<br>';
}
107lab
admin
admin
$dbms='mysql';//数据库类型
$dbName='admin';//使用的数据库
$user='root';//数据库连接用户名
$pwd='password';//数据库连接密码
$host='localhost';//数据库主机名
$dsn="$dbms:host=$host;port=3306;dbname=$dbName";
try{
$pdo=new PDO($dsn,$user,$pwd);//初始化一个PDO对象,就是创建了数据库连接对象$pdo
$query="select * from user";//需要执行的sql语句
$res=$pdo->prepare($query);//准备查询语句
$res->execute();
echo $res->fetchColumn(0).'<br>';
echo $res->fetchColumn(0).'<br>';
echo $res->fetchColumn(0).'<br>';
}catch(Exception $e){
die("Error!:".$e->getMessage().'<br>');
}
1
4
5