php使用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()方法完成数据的循环输出
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
$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
2
3
|
1 107lab e10adc3949ba59abbe56e057f20f883e 4 admin 123456 5 admin 123456 |
fetchAll()方法
fetchAll()方法用于获取结果集中的所有行,其返回值是一个包含结果集中所有数据的二进制数组。语法如下:
array PDOStatement::fetchAll([int fetch_style[,int column_index]])
参数说明:
fetch_style:控制结果集中数据的显示方式。
column_index: 字段的索引。
例如:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
$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>' ); } |
运行结果为:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
|
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来遍历这个二维数组
1
2
3
|
foreach ( $result as $val ){ echo $val [ 'username' ]. '<br>' ; } |
运行结果为:
1
2
3
|
107lab admin admin |
fetchColumn()方法
fetchColumn()方法获取结果集中下一行指定列的值,语法如下:
string PDOStatement::fetchColumn([int column_number])
可选参数column_number设置行中列的索引值,该值从0开始。如果省略该参数则将从第1列开始取值
例如:
通过fetchColumn()方法获取结果集中下一行中指定列的值。(或第一列id的值)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
$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
2
3
|
1 4 5 |
php使用PDO获取结果集的方法的更多相关文章
- PHP PDO获取结果集
一.介绍PDO获取结果集,不得不介绍一下PDO是如果执行SQL语句,一般情况下分三种, 1.query()方法 query()方法通常用于返回执行查询后的结果集.语法是这样的:PDOStatement ...
- PDO获取数据的方法fetch()、fetchAll()、setFetchMode()、bindColumn()
PDO的数据获取方法与其他数据库扩展都非常类似,只要成功执行SELECT查询,都会有结果集对象产生.不管是使用PDO对象中的query()方法,还是使用prepare()和execute()等方法结合 ...
- PDO中获取结果集
fetch()方法 fetch()方法用于获取结果集的下一行.语法例如以下: mixed PDOStatement::fetch([int fetch_style][,int cursor_orien ...
- C#处理MySql多个返回集的方法
本文实例讲述了C#处理MySql多个返回集的方法.分享给大家供大家参考.具体方法如下: 关于Mysql返回多个集java和Php的较多,但是C#的完整代码好像没见过,研究了一下做个封装以后用 做一个M ...
- [No00006F]总结C#获取当前路径的各种方法
using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; usin ...
- VMware桥接模式无法自动化获取IP的解决方法
虚拟机桥接无法自动获取IP的解决方法 在虚拟机VM里面装了centos系统,网卡选用桥接方式. 刚开始的时候还能自动获取到IP地址,突然有一天IP消失了,再怎么重启都无法获取IP地址.因为之前是可以获 ...
- C#的path.GetFullPath 获取上级目录实现方法
这篇文章主要介绍了C#的path.GetFullPath 获取上级目录实现方法,包含了具体的C#实现方法以及ASP.net与ASP等的方法对比,非常具有实用价值,需要的朋友可以参考下 本文实例讲述 ...
- 多浏览器兼容用javascript获取url参数的方法比较推荐的一种
多浏览器兼容用javascript获取url参数的方法比较推荐的一种 <script language = javascript> function request(paras){ var ...
- 使用jquery获取url以及jquery获取url参数的方法
使用jquery获取url以及使用jquery获取url参数是我们经常要用到的操作 1.jquery获取url很简单,代码如下 1.window.location.href; 其实只是用到了javas ...
- Spring3 MVC请求参数获取的几种方法
Spring3 MVC请求参数获取的几种方法 一. 通过@PathVariabl获取路径中的参数 @RequestMapping(value="user/{id}/{name}&q ...
随机推荐
- 单点登录系统使用Spring Security的权限功能
背景 在配置中心增加权限功能 目前配置中心已经包含了单点登录功能,可以通过统一页面进行登录,登录完会将用户写入用户表 RBAC的用户.角色.权限表CRUD.授权等都已经完成 希望不用用户再次登录,就可 ...
- go-carbon 1.5.0 版本发布,修复已知 bug 和新增德语翻译文件
carbon 是一个轻量级.语义化.对开发者友好的golang时间处理库,支持链式调用. 目前已被 awesome-go 收录,如果您觉得不错,请给个star吧 github:github.com/g ...
- TypeError: Object(…) is not a function
vue中遇到的这个错误 1. 先检查变量名或者函数名是否有重复定义 报这错之后看了好久,也没有发现starkflow上说的,重复定义了变量或者函数 2. vue的话 检查下函数写的位置,直接写到cre ...
- ubuntu1804搭建FTP服务器的方法
搭建FTP服务器 FTP的工作原理: FTP:File Transfer Protocol ,文件传输协议.属于NAS存储的一种协议,基于CS结构. ftp采用的是双端口模式,分为命令端口和数据端口, ...
- python Flask 操作数据库
Flask数据库 转载:Flask数据库 - 苦行僧95 - 博客园 (cnblogs.com) Flask-SQLAlchemy Flask-SQLAlchemy是在Flask中操作关系型数据库的拓 ...
- Windows上使用QEMU创建银河麒麟ARM64虚拟机完全手册
"好记性不如烂笔头." -- 张溥 0x00 大纲 目录 0x00 大纲 0x01 前言 0x02 物料准备 0x03 安装 QEMU 0x04 创建虚拟磁盘 0x05 安装麒麟系 ...
- 【转载】WebBrowser控件的常用方法、属性和事件
1. 属性 属性 说明 Application 如果该对象有效,则返回掌管WebBrowser控件的应用程序实现的自动化对象(IDispatch).如果在宿主对象中自动化对象无效,这个程序将返回Web ...
- 一个实现单线程/多线程下代码调用链中传递数据的处理类: CallContext(LogicalSetData,LogicalGetData),含.net core的实现
详情请参考原文:一个实现单线程/多线程下代码调用链中传递数据的处理类: CallContext
- 【rabbitmq】单独配置某一个消费者手动ack,其他消费者自动ack
前言:博主才疏学浅,此方案仅供参考,如有更优方案请大佬评论区告知,十分感谢✿✿ヽ(°▽°)ノ✿ 问题背景:同一个服务中存在多个不同业务的rabbitmq的消费者,其中一个推送业务的消费者需要加死信队列 ...
- Springboot整合策略模式概念->使用场景->优缺点->企业级实战
一.前言 策略模式可能是在工作中使用最多的,也是在面试中最常提到的,代码重构和优化的必备! 小编之前也是一直说,其实没有真正的实战:最近有了机会实战了一下,来分享一下使用心得和在企业级的使用! 二.策 ...