我是靠谱客的博主 含蓄世界,最近开发中收集的这篇文章主要介绍php mysql_fetch_array pdo_php使用PDO获取结果集的方法,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

本文实例讲述了php使用PDO获取结果集的方法。分享给大家供大家参考,具体如下:

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对象的一个滚动游标,可用于获取指定的一行。

cursor_offset: 游标的偏移量

例如:

在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'].'
';

}

}catch(Exception $e){

die("Error!:".$e->getMessage().'
');

}

运行结果为:

1 107lab e10adc3949ba59abbe56e057f20f883e

4 admin 123456

5 admin 123456

fetchAll()方法

fetchAll()方法用于获取结果集中的所有行,其返回值是一个包含结果集中所有数据的二进制数组。语法如下:

array PDOStatement::fetchAll([int fetch_style[,int column_index]])

参数说明:

fetch_style:控制结果集中数据的显示方式。

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().'
');

}

运行结果为:

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来遍历这个二维数组

foreach($result as $val){

echo $val['username'].'
';

}

运行结果为:

107lab

admin

admin

fetchColumn()方法

fetchColumn()方法获取结果集中下一行指定列的值,语法如下:

string PDOStatement::fetchColumn([int column_number])

可选参数column_number设置行中列的索引值,该值从0开始。如果省略该参数则将从第1列开始取值

例如:

通过fetchColumn()方法获取结果集中下一行中指定列的值。(或第一列id的值)

$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).'
';

echo $res->fetchColumn(0).'
';

echo $res->fetchColumn(0).'
';

}catch(Exception $e){

die("Error!:".$e->getMessage().'
');

}

运行结果为:

1

4

5

希望本文所述对大家PHP程序设计有所帮助。

最后

以上就是含蓄世界为你收集整理的php mysql_fetch_array pdo_php使用PDO获取结果集的方法的全部内容,希望文章能够帮你解决php mysql_fetch_array pdo_php使用PDO获取结果集的方法所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(55)

评论列表共有 0 条评论

立即
投稿
返回
顶部