Zend Framework框架教程之Zend_Db_Table_Rowset用法实例分析

6年以前  |  阅读数:832 次  |  编程语言:PHP 

本文实例讲述了Zend Framework框架Zend_Db_Table_Rowset用法。分享给大家供大家参考,具体如下:

1. 简介

Zend_Db_Table_Rowset是 Zend_Db_Table_Row对象集合的迭代器.通常来说,你不可以自己实例化Zend_Db_Table_Rowset, 而是通过调用Zend_Db_Table::find()方法或者fetchAll()方法将Zend_Db_Table_Rowset作为 结果数据返回过来.接下来就可以遍历Zend_Db_Table_Row对象集合并进行修改.

2. 取回结果集

首先,需要实例化一个Zend_Db_Table类.


    <?php
    // 设置一个 adapter
    require_once 'Zend/Db.php';
    $params = array (
      'host'   => '127.0.0.1',
      'username' => 'malory',
      'password' => '******',
      'dbname'  => 'camelot'
    );
    $db = Zend_Db::factory('PDO_MYSQL', $params);
    // 为所有的Zend_Db_Table对象设置默认
    require_once 'Zend/Db/Table.php';
    Zend_Db_Table::setDefaultAdapter($db);
    // 连接数据库表
    class RoundTable extends Zend_Db_Table {}
    $table = new RoundTable();
    ?>

接下来,可以使用Zend_Db_Table::find()方法和多个键值,或者使用Zend_Db_Table::fetchAll()方法对数据库进行查询,
返回的结果是一个Zend_Db_Table_Rowset对象,可以通过该对象遍历结果集中的每一个Zend_Db_Table_Row对象.


    <?php
    // 从表中取回多条记录
    $rowset = $table->fetchAll();
    //
    // $rowset现在是一个Zend_Db_Table_Rowset对象,该对象中每条记录就是一个Zend_Db_Table_Row对象
    //
    ?>

3. 遍历结果集

Zend_Db_Table_Rowset实现了简单程序设计语言的迭代器接口,也就是说,可以对Zend_Db_Table_Rowset 对象进行循环处理,就像使用foreach()函数处理数组一样.使用这种方法取回的每一个值都是一个对应表 中数据的Zend_Db_Table_Row对象,你可以查看,修改和保存该对象的属性(即表中的字段值.)


    <?php
    // 连接到数据库中的表
    class RoundTable extends Zend_Db_Table {}
    $table = new RoundTable();
    // 从表中取回多条记录
    $rowset = $table->fetchAll();
    // 显示所有的记录
    foreach ($rowset as $row) {
      // $row 是一个 Zend_Db_Table_Row 对象
      echo "<p>" . htmlspecialchars($row->nobleTitle) . " "
        . htmlspecialchars($row->firstName) . "'s "
        . "favorite color is " . htmlspecialchars($row->favoriteColor)
        . ".</p>/n";
      // 更新我们显示改行的次数
      // (对应表中的"times_displayed"字段)
      $row->timesDisplayed ++;
      // 保存新记录.
      $row->save();
    }
    ?>

更多关于zend相关内容感兴趣的读者可查看本站专题:《Zend FrameWork框架入门教程》、《php优秀开发框架总结》、《Yii框架入门及常用技巧总结》、《ThinkPHP入门教程》、《php面向对象程序设计入门教程》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总

希望本文所述对大家基于Zend Framework框架的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分页类完整实例