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

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

 1、fetch()方法

PDOStatement类中的fetch()方法可以将结果集中当前的记录以某种方式返回,并将结果集指针移至下一行,当到达结果集末尾时返回FALSE。该方法的原型如下:

mixed PDOStatement::fetch ([ int $fetch_style [, int $cursor_orientation = PDO::FETCH_ORI_NEXT [, int $cursor_offset = 0 ]]] )

第一个参数fetch_style是可选项,获取一行数据记录中,各列的引用方式取决于这个参数如何设置。可以使用的设置有以下6种。

PDO::FETCH_ASSOC          从结果集中获取以列名为索引的关联数组。
       PDO::FETCH_NUM             从结果集中获取一个以列在行中的数值偏移量为索引的值数组。
       PDO::FETCH_BOTH            这是默认值,包含上面两种数组。
       PDO::FETCH_OBJ               从结果集当前行的记录中获取其属性对应各个列名的一个对象。
       PDO::FETCH_BOUND        使用fetch()返回TRUE,并将获取的列值赋给在bindParm()方法中指 定的相应变量。
       PDO::FETCH_LAZY            创建关联数组和索引数组,以及包含列属性的一个对象,从而可以在这三种接口中任选一种。

第二个参数cursor_orientation是可选项,用来确定当对象是一个可滚动的游标时应当获取哪一行。

第三个参数cursor_offset也是可选项,需要提供一个整数值,表示要获取的行相对于当前游标位置的偏移。

在下面的示例中,使用PDO对象中的query()方法执行SELECT查询,获取联系人信息表contactinfo中的信息,并返回PDOStatement类对象作为结果集。然后通过fetch()方法结合while循环遍历数据,并以HTML表格的形式输出。代码如下所示:


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

<?php

    try {

        $dbh = new PDO(‘mysql:dbname=testdb;host=localhost‘, $username, $passwd);

    }catch (PDOException $e){

        echo ‘数据库连接失败:‘.$e->getMessage();

        exit;

    }

    echo ‘<table border="1" align="center" width=90%>‘;

    echo ‘<caption><h1>联系人信息表</h1></caption>‘;

    echo ‘<tr bgcolor="#cccccc">‘;

    echo ‘<th>UID</th><th>姓名</th><th>联系地址</th><th>联系电话</th><th>电子邮件</th></tr>‘;

    //使用query方式执行SELECT语句,建议使用prepare()和execute()形式执行语句

    $stmt = $dbh->query("select uid,name,address,phone,email FROM contactinfo");

    //以PDO::FETCH_NUM形式获取索引并遍历

    while (list($uid,$name,$address,$phone,$email)=$stmt->fetch(PDO::FETCH_NUM)){

        echo ‘<tr>‘;

        echo ‘<td>‘.$uid.‘</td>‘;

        echo ‘<td>‘.$name.‘</td>‘;

        echo ‘<td>‘.$address.‘</td>‘;

        echo ‘<td>‘.$phone.‘</td>‘;

        echo ‘<td>‘.$email.‘</td>‘;

        echo ‘</tr>‘;

    }

    echo ‘</table>‘;

?>

2、fetchAll()方法

fetchAll()方法与上一个方法fetch()类似,但是该方法只需要调用一次就可以获取结果集中的所有行,并赋给返回的数组(二维)。该方法的原型如下:

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

fetchAll()方法的应用示例如下所示:


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

    try {

        $dbh = new PDO(‘mysql:dbname=testdb;host=localhost‘, $username, $passwd);

    }catch (PDOException $e){

        echo ‘数据库连接失败:‘.$e->getMessage();

        exit;

    }

    echo ‘<table border="1" align="center" width=90%>‘;

    echo ‘<caption><h1>联系人信息表</h1></caption>‘;

    echo ‘<tr bgcolor="#cccccc">‘;

    echo ‘<th>UID</th><th>姓名</th><th>联系地址</th><th>联系电话</th><th>电子邮件</th></tr>‘;

    //使用query方式执行SELECT语句,建议使用prepare()和execute()形式执行语句

    $stmt = $dbh->prepare("select uid,name,address,phone,email FROM contactinfo");

    $stmt->execute();

    $allrows = $stmt->fetchAll(PDO::FETCH_ASSOC);       //以关联下标从结果集中获取所有数据

    //以PDO::FETCH_NUM形式获取索引并遍历

   foreach($allrows as $row){

        echo ‘<tr>‘;

        echo ‘<td>‘.$row[‘uid‘].‘</td>‘;

        echo ‘<td>‘.$row[‘name‘].‘</td>‘;

        echo ‘<td>‘.$row[‘$address‘].‘</td>‘;

        echo ‘<td>‘.$row[‘phone‘].‘</td>‘;

        echo ‘<td>‘.$row[‘email‘].‘</td>‘;

        echo ‘</tr>‘;

    }

    echo ‘</table>‘;

    //以下是在fetchAll()方法中使用两个特别参数的演示示例

    $stmt->execute();

    $row = $stmt->fetchAll(PDO::FETCH_COLUMN,1);   //从结果集中获取第二列的所有值

    echo ‘所有联系人的姓名:‘;

    print_r($row);

?>

 3、setFetchMode()方法

PDOStatement对象中的fetch()和fetchAll()两个方法,获取结果数据的引用方式默认都是一样的,既按列在行中的数值偏移量(从0开始)索引的值数组,因为它们的默认模式都被设置为PDO::FETCH_BOTH值。如果计划使用其他模式来改变这个默认设置,可以在fetch()或fetchAll()方法中提供需要的模式参数。但如果多次使用这两个方法,在每次调用时都需要设置新的模式来改变默认的模式。这时就可以使用PDOStatement类对象中的setFetchMode()方法,在脚本页面的顶部设置一次模式,以后所有fetch()和fetchAll()方法的调用都将生成相应的结果集,减少了多次在调用fetch()方法时的参数录入。

4、bindColumn()方法

使用该方法可以将一个列和一个指定的变量名绑定,这样在每次使用fetch()方法获取各行记录时,会自动将相应的列值赋给该变量,但必须是在fetch()方法的第一个参数设置为PDO::FETCH_BOTH值时。bindColumn()方法的原型如下所示:

 bool PDOStatement::bindColumn ( mixed $column , mixed &$param [, int $type [, int $maxlen [, mixed $driverdata ]]] )

第一个参数column为必选项,可以使用整数的列偏移位置索引(索引值从1开始),或是列的名称字符串。第二个参数param也是必选项,需要传递一个引用,所以必须提供一个相应的变量名。第三个参数type是可选项,通过设置变量的类型来限制变量值,该参数支持的值和介绍bindparam()方法时提供的一样。该方法的应用示例如下所示:


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

<?php

    try {

        $dbh = new PDO(‘mysql:dbname=testdb;host=localhost‘, $username, $passwd);

        $dbh = setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_EXCEPTION);

    }catch (PDOException $e){

        echo ‘数据库连接失败:‘.$e->getMessage();

        exit;

    }

     $query="select uid,name,,phone,email FROM contactinfo WHERE departmentId=d01‘";

   try {

    $stmt = $dbh->prepare($query);

    $stmt->execute();

    $stmt->bindColumn(1,$uid);

    $stmt->bindColumn(2,$name);

    $stmt->bindColumn(‘phone‘,$phone);

    $stmt->bindColumn(‘email‘,$email);

    while ($stmt->fetch(PDO::FETCH_BOUND)){

        echo $uid."\t".$name."\t".$phone."\t".$email."\n";

    }

   }catch (PDOException $e){

    echo $e->getMessage();

   }

?>

5、获取数据列属性信息

在项目开发中,除了尅通过上面的几种方式获取数据表中的记录信息外,还可以使用PDOStatement类对象的columnCount()方法获取数据表中字段的数量,并且可以通过PDOStatement类对象的getColumnMeta()方法获取具体列的属性信息。

时间: 2024-11-20 04:36:27

PDO获取数据的方法fetch()、fetchAll()、setFetchMode()、bindColumn()的相关文章

React 中的 AJAX 请求:获取数据的方法

React 中的 AJAX 请求:获取数据的方法 React 只是使用 props 和 state 两处的数据进行组件渲染. 因此,想要使用来自服务端的数据,必须将数据放入组件的 props 或 state 中. 首先引入 axios. 1.`import axios from 'axios';` constructor 方法非常标准,调用 super,然后初始化 state,设置一个空的 posts 数 传入新的 posts 数组,使用 this.setState 方法更新组件状态.这会导致重

Swift - 后台获取数据(Background Fetch)的实现

前面讲了如何让程序申请后台短时运行.但这个额外延长的时间毕竟有限.所以从iOS7起又引入两种在后台运行任务的方式:后台获取和后台通知. 1,后台获取介绍 后台获取(Background Fetch)是为了那些需要定期更新的应用程序设计的,比如天气应用,新闻客户端,社交网络应用程序等.在启动后台获取之后,应用程序可以在后台被唤醒,在后台获取最新信息,以便在用户将应用程序转到前台时能够立即显示这些信息. 2,后台获取功能开启 首先在选中项目,在Capabilities(功能)选项卡,启用Backgr

MySQL随机获取数据的方法,支持大数据量

最近做项目,需要做一个从mysql数据库中随机取几条数据出来. 总所周知,order by rand 会死人的..因为本人对大数据量方面的只是了解的很少,无解,去找百度老师..搜索结果千篇一律.特发到这里来,供大家学习. 在mysql中带了随机取数据的函数,在mysql中我们会有rand()函数,很多朋友都会直接使用,如果几百条数据肯定没事,如果几万或百万时你会发现,直接使用是错误的.下面我来介绍随机取数据一些优化方法. SELECT * FROM table_name ORDER BY ran

vue 中使用 AJAX获取数据的方法

在VUE开发时,数据可以使用jquery和vue-resource来获取数据.在获取数据时,一定需要给一个数据初始值. 看下例: <script type="text/javascript"> new Vue({ el:'#app', data:{data:""}, created:function(){ var url="json.jsp"; var _self=this; $.get(url,function(data){ _se

Java从控制台获取数据的方法

一.使用System.in.read()一次获取一个字节 输入再多数据,只会获取第一个字节的int形式.获取的是字节,而不是字符,所以如果输入中文字符,强转后会得到乱码 1 try { 2 int in_num=System.in.read(); //获取的是一个字节的int类型 3 System.out.println("强转前:"+in_num); 4 System.out.println("强转后:"+(char)in_num); 5 } catch (IOE

UniGui中使用Grid++Report报表控件子报表获取数据的方法

Grid++Report是为优秀的报表控件,子报表是其重要功能之一,但Grid++Report提供的网页报表示范主要是以页面为主的,UniGui在Delphi中以快速编写web管理软件著称,但由于资料文档很少,经过摸索,Grid++Report的子报表要在uniGUi中正确获取子报表数据,只能通过Ajax数据回调的方式进行,在uniGUi中对前端Ajax的响应,就要是通过控件的AjaxEvent事件来处理.报表模板的展示部分的HTML代码要放在UniURLFrame控件的HTML属性中.Ajax

6.Request的三种获取数据的方法

其实一共有4种,不过form这种专门获取以post方式提交数据的方式目前还没学.所以就不太演示了 另外需要注意的是,Request.params 这种获取方式能不用就不要用了,有时候会出问题 那么代码如下: 第一个页面是index.aspx的代码: 第一个页面的index.aspx.cs的代码: 这里要说一下,上面这行语句,我在问号后面多打了一个空格,结果运行的时候就报错了!!!说没找到页面! 第二个页面的test.aspx.cs的代码: 原文地址:https://www.cnblogs.com

前台向后台传值的两种方法 以及 从后台获取数据的方法

1.前台向后台传值方法一: 表单提交的方式: 1 <form action="${path }/manage/logon.do" method="post" id="logonForm"> 2 <table cellpadding="0" cellspacing="0" border="0"> 3 <tr height="50">

PHP从mysql获取数据的方法

1 <?php 2 require "database.php"; 3 //读取数据库中的数据 4 $sql_1 = "SELECT * FROM test_table"; 5 $result = $db_conn->query($sql_1); 6 while ( $row = mysqli_fetch_assoc($result) ) {//此处不能使用foreach 7 var_dump($row); 8 echo "<hr>