PHP PDO获取结果集

一、介绍PDO获取结果集,不得不介绍一下PDO是如果执行SQL语句,一般情况下分三种,

1.query()方法

query()方法通常用于返回执行查询后的结果集。语法是这样的:PDOStatement PDO::query(string sql);

参数sql就很容易理解了,就是要执行的sql语句。

2.prepare()方法和execute()方法

   prepare()是预处理语句的其中一个方法,通常来做查询的准备工作,然后,execute()来执行查询。

以上就简单介绍这三种情况。

二、PDO如何获取结果集

   pdo获取结果集有三种方法,分别是fetch()、fetchAll()和fetchColumn()方法。

 首先,你先在数据库里面建一个表,命名为t_user。

CREATE TABLE `t_user` (
   `userid` int(11) NOT NULL,
   `username` varchar(25) DEFAULT NULL,
   `usersex` varchar(6) DEFAULT NULL,
  `userage` int(6) DEFAULT NULL,
   PRIMARY KEY (`userid`)
  ) ENGINE=InnoDB DEFAULT CHARSET=utf8;

然后,插入数据,很简单,如下:

INSERT INTO `t_user` VALUES (‘1‘, ‘li‘, ‘boy‘, ‘23‘);
 INSERT INTO `t_user` VALUES (‘2‘, ‘nadia‘, ‘gril‘, ‘20‘);
 INSERT INTO `t_user` VALUES (‘3‘, ‘wang‘, ‘boy‘, ‘55‘);

下面就简单介绍一下每个方法是如何使用的。

1.fetch()方法

fecth()方法是获取结果集的下一行数据。

表一: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种形式返回结果。

ftech()方法的具体代码如下所示:

   <table border=‘1‘>
    <?php
      $dbms = ‘mysql‘;//选择mysql数据库
      $host = ‘127.0.0.1‘;//数据库主机名
      $dbName = ‘dbtext‘;//使用的数据库
      $user = "";//数据库连接用户名
      $pwd = "";//数据库连接密码
      $dsn = "$dbms:host=$host;dbname=$dbName";
      try {
        $pdo = new PDO($dsn, $user, $pwd);//初始化一个PDO对象,创建数据库连接对象$pdo
        $query = "select * from t_user";
        $result = $pdo->prepare($query);
        $result->execute();
        while ($res=$result->fetch(PDO::FETCH_ASSOC)){?>
      <tr>
      <td><?php echo $res[‘userid‘];?></td>
      <td><?php echo $res[‘username‘];?></td>
      <td><?php echo $res[‘userage‘];?></td>
      <td><?php echo $res[‘usersex‘];?></td>
      </tr>
    <?php }
    }catch (Exception $e){
    die("error!!!".$e->getMessage()."<br>");
    }
    ?>
  </table>

结果如下图1:

图1

2.fetchAll()方法

从单词上可以看的很清楚,fetchAll()方法是为了获取结果集的所有行。

时间: 2024-08-30 08:14:27

PHP PDO获取结果集的相关文章

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

PDO中获取结果集之fetchColumn()方法详解

fetchCloumn()方法是获取结果集中下一行指定列的值,从结果集中的下一行返回单独的一列.直线电机品牌 那么我们在前面两篇文章<PDO中获取结果集之fetchAll()方法详解>和<PDO中获取结果集之fetch()方法详解>中我们介绍了两种类似的PDO中获取结果集的方法,那么我们接下来跟大家介绍fetchColumn()方法! 下面我们先看下fetchColumn()方法的语法格式如下: 1 string PDOStatement::fetchColumn ([ int $

PDO中获取结果集之fetchAll()方法详解

fetchAll()方法是获取结果集中的所有行,返回一个包含结果集中所有行的二进制数组!大理石机械构件维修厂家 那么在上一篇<PDO中获取结果集之fetch()方法详解>中,我们介绍了fetch()方法获取结果集,我们今天将要介绍的fetchAll()方法与上一个方法fetch()类似,但是该方法只需要调用一次就可以获取结果集中的所有行,并赋给返回的数组(二维). fetchAll()方法的语法格式如下: 1 array PDOStatement::fetchAll ([ int $fetch

获取笑话集网站笑话数据的后台代码

最近做了一个app用于获取笑话集网站的数据,为了方便开发.我先用PHP对数据进行了预处理 代码如下   <?php include_once("writeLog.php"); class Joke { var $jokeText = ""; var $urlNext = ""; var $urlPrv = ""; var $urlBase = "http://wap.jokeji.cn/"; func

mysql查询分组之后获取结果集总数

相信分页查询对于很多开发者来说都是司空见惯的事情,首先按照查询条件搜索出分页列表数据和总的记录数,获取总的记录数一般是: select count(1) as total from xxx where .......... 这没有问题,但是如果查询的条件有分组group by 那这个时候获取总数就有问题了,这样是获取每个分组的总数 解决办法: select count(1) as total from ( select id from xxx where .... grouy by .....)

PDO中获取结果集之fetch()方法详解

fetch()方法获取结果集中的下一行数据,该函数的具体语法格式如下:大理石平台检定规程 1 mixed PDOStatement::fetch ([ int $fetch_style [, int $cursor_orientation = PDO::FETCH_ORI_NEXT [, int $cursor_offset = 0 ]]] ) 参数 fetch_style:控制结果集的返回方式,其中可选择的值如下表: 值 说 明 PDO::FETCH_ASSOC 关联数组形式. PDO::FE

PDO获取数据的方法fetch()、fetchAll()、setFetchMode()、bindColumn()

PDO的数据获取方法与其他数据库扩展都非常类似,只要成功执行SELECT查询,都会有结果集对象产生.不管是使用PDO对象中的query()方法,还是使用prepare()和execute()等方法结合的预处理语句,执行SELECT查询都会得到相同的结果集对象PDOStatement.都需要通过PDOStatement类对象中的方法将数据遍历出来.下面介绍PDOStatement类中常见的几个获取结果集数据的方法. 1.fetch()方法 PDOStatement类中的fetch()方法可以将结果

【K8S学习笔记】Part2:获取K8S集群中运行的所有容器镜像

本文将介绍如何使用kubectl列举K8S集群中运行的Pod内的容器镜像. 注意:本文针对K8S的版本号为v1.9,其他版本可能会有少许不同. 0x00 准备工作 需要有一个K8S集群,并且配置好了kubectl命令行工具来与集群通信.如果未准备好集群,那么你可以使用Minikube创建一个K8S集群,或者你也可以使用下面K8S环境二者之一: Katacoda Play with Kubernetes 如果需要查看K8S版本信息,可以输入指令kubectl version. 在本练习中,我们将使

Hibernate hql 查询指定字段并获取结果集(转)

在hibernate中,用hql语句查询实体类,采用list方法的返回结果为一个List,该List中封装的对象分为以下三种情况:1.查询全部字段的情况下,如"from 实体类",list中封装的对象为实体类本身,各属性都将得到填充.2.只查询一个字段,默认情况下,list中封装的是Object对象.3.查询两个或两个以上的字段,默认情况下,list中封装的是Object[],长度与所查询的字段数一致. 对于后两种情况,用标签遍历时不太方便,因为无法直接转换成实体类的对象.比较简单的解