当前位置:首页 > PHP教程 > Zend > 列表

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

发布:smiling 来源: PHP粉丝网  添加日期:2021-07-20 21:11:00 浏览: 评论:0 

这篇文章主要介绍了Zend Framework框架教程之Zend_Db_Table_Rowset用法,结合实例形式分析了Zend_Db_Table_Rowset操作结果集的相关技巧,需要的朋友可以参考下

本文实例讲述了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类.

  1. <?php 
  2. // 设置一个 adapter 
  3. require_once 'Zend/Db.php'
  4. $params = array ( 
  5.   'host'   => '127.0.0.1'
  6.   'username' => 'malory'
  7.   'password' => '******'
  8.   'dbname'  => 'camelot' 
  9. ); 
  10. $db = Zend_Db::factory('PDO_MYSQL'$params); 
  11. // 为所有的Zend_Db_Table对象设置默认 
  12. require_once 'Zend/Db/Table.php'
  13. Zend_Db_Table::setDefaultAdapter($db); 
  14. // 连接数据库表 
  15. class RoundTable extends Zend_Db_Table {} 
  16. $table = new RoundTable(); 
  17. ?> 

接下来,可以使用Zend_Db_Table::find()方法和多个键值,或者使用Zend_Db_Table::fetchAll()方法对数据库进行查询,

返回的结果是一个Zend_Db_Table_Rowset对象,可以通过该对象遍历结果集中的每一个Zend_Db_Table_Row对象.

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

3. 遍历结果集

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

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

Tags: Framework Zend_Db_Table_Rowset

分享到: