zoukankan      html  css  js  c++  java
  • PDO中获取结果集之fetchAll()方法详解

    fetchAll()方法是获取结果集中的所有行,返回一个包含结果集中所有行的二进制数组!大理石机械构件维修厂家

    那么在上一篇《PDO中获取结果集之fetch()方法详解》中,我们介绍了fetch()方法获取结果集,我们今天将要介绍的fetchAll()方法与上一个方法fetch()类似,但是该方法只需要调用一次就可以获取结果集中的所有行,并赋给返回的数组(二维)。

    fetchAll()方法的语法格式如下:

    1

    array PDOStatement::fetchAll ([ int $fetch_style [, mixed $fetch_argument [, array $ctor_args = array() ]]] )

    参数 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种形式返回结果。

    参数 column_index:字段的索引!

    其返回值是一个包含结果集中所有数据的二维数组。

    下面我们通过 fetchAll()方法获取结果集中的所有行,并且通过 for 语句读取二维数组中的数据,完成数据库中数据的循环输出,具体步骤如下:

    首先创建php文件,通过 PDO 连接MySQL 数据库,然后定义 SELECT查询语句,应用 prepare()和execute()方法执行查询操作,接着,通过fetchAll()方法返回结果集中的所有行,最后使用 for 语句完成结果集中所有数据的循环输出,代码如下:

    1

    2

    3

    4

    5

    6

    7

    8

    9

    10

    11

    12

    13

    14

    15

    16

    17

    18

    19

    20

    21

    22

    23

    24

    25

    26

    27

    28

    29

    30

    31

    32

    33

    34

    35

    36

    <?php

    header("Content-Type:text/html; charset=utf-8");    //设置页面的编码格式

    $dbms = "mysql";                                  // 数据库的类型

    $dbName ="php_cn";                                //使用的数据库名称

    $user = "root";                                   //使用的数据库用户名

    $pwd = "root";                                    //使用的数据库密码

    $host = "localhost";                              //使用的主机名称

    $dsn  = "$dbms:host=$host;dbname=$dbName";

    try{

        $pdo=new PDO($dsn,$user,$pwd);//初始化一个PDO对象,就是创建了数据库连接对象$pdo

        $query="select * from user";//需要执行的sql语句

        $res=$pdo->prepare($query);//准备查询语句

        $res->execute();            //执行查询语句,并返回结果集

        ?>

        <table border="1" width="500">

            <tr>

                <td height="22" align="center" valign="middle">id</td>

                <td height="22" align="center" valign="middle">用户名</td>

                <td height="22" align="center" valign="middle">密码</td>

            </tr>

            <?php

      $result=$res->fetchAll(PDO::FETCH_ASSOC) ;        // 获取结果集中的所有数据。

            for ($i=0;$i<count($result);$i++){          //循环读取二维数组中的数据。

            ?>

            <tr>

            <td height="22" align="center" valign="middle"><?php echo $result[$i]['id'];?></td>

            <td height="22" align="center" valign="middle"><?php echo $result[$i]['username'];?></td>

            <td height="22" align="center" valign="middle"><?php echo $result[$i]['password'];?></td>

            </tr>

    <?php

        }

    }catch(Exception $e){

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

    }

    ?>

    </table>

  • 相关阅读:
    vue学习6
    vue学习5
    vue学习3
    vue学习2
    vue学习1
    idea快速查找和替换快捷键
    mysql三元表达式
    1 Java Lambda表达式forEach无法跳出循环的解决思路
    6 Mybatis Plus and 和 or,分页Page使用
    4 Mybatis Plus使用redis作为二级缓存
  • 原文地址:https://www.cnblogs.com/furuihua/p/12172730.html
Copyright © 2011-2022 走看看