php使用PDO获取结果集的方法

5年以前  |  阅读数:255 次  |  编程语言:PHP 

本文实例讲述了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'].'<br>';
      }
    }catch(Exception $e){
    die("Error!:".$e->getMessage().'<br>');
    }

运行结果为:


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

运行结果为:


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

运行结果为:


    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).'<br>';
      echo $res->fetchColumn(0).'<br>';
      echo $res->fetchColumn(0).'<br>';
    }catch(Exception $e){
      die("Error!:".$e->getMessage().'<br>');
    }

运行结果为:


    1
    4
    5

更多关于PHP相关内容感兴趣的读者可查看本站专题:《PHP基于pdo操作数据库技巧总结》、《php+Oracle数据库程序设计技巧总结》、《PHP+MongoDB数据库操作技巧大全》、《php面向对象程序设计入门教程》、《php字符串(string)用法总结》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总

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

 相关文章:
PHP分页显示制作详细讲解
SSH 登录失败:Host key verification failed
获取IMSI
将二进制数据转为16进制以便显示
获取IMEI
文件下载
贪吃蛇
双位运算符
PHP自定义函数获取搜索引擎来源关键字的方法
Java生成UUID
发送邮件
年的日历图
提取后缀名
在Zeus Web Server中安装PHP语言支持
让你成为最历害的git提交人
Yii2汉字转拼音类的实例代码
再谈PHP中单双引号的区别详解
指定应用ID以获取对应的应用名称
Python 2与Python 3版本和编码的对比
php封装的page分页类完整实例