博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
PDO中获取结果集
阅读量:6803 次
发布时间:2019-06-26

本文共 2988 字,大约阅读时间需要 9 分钟。

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

转载地址:http://vauwl.baihongyu.com/

你可能感兴趣的文章
提高IO性能(只需要设置 noatime)
查看>>
批处理 启动和关闭 Oracle 11g 服务
查看>>
二手车服务商完成A轮融资,投资方为标志雪铁龙集团
查看>>
一文读懂什么是Java中的自动拆装箱
查看>>
java函数式编程
查看>>
获5.3亿美金融资,亚马逊、红杉入局,自动驾驶“梦之队”Aurora还藏了哪些秘招?...
查看>>
C#-Xamarin利用ZXing.Net.Mobile进行扫码
查看>>
网站有漏洞被攻击篡改了数据该怎么修复解决
查看>>
抖音短视频开发项目跨入社交圈,头条实现社交梦?
查看>>
亲测 | 如何更高效的管理原生微服务应用
查看>>
jQuery UI 自定义样式的日历控件
查看>>
成为优秀UI设计师,必须了解的UI设计规范
查看>>
Memcached源码分析 - LRU淘汰算法(6)
查看>>
数据类型
查看>>
Jenkins 插件之环境变量插件EnvInject(学习笔记十三)
查看>>
PowerShell收集服务器日检报告,并发邮件给指定人员
查看>>
windows命令行删除所有文件和子目录
查看>>
网球机器人入侵火星 从单独工作到团队协作
查看>>
java中多种写文件方式的效率对比实验
查看>>
升级Xcode7之后如果遇到下面的错误
查看>>