欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

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

程序员文章站 2024-04-01 22:19:34
本文实例讲述了zend framework框架zend_db_table_rowset用法。分享给大家供大家参考,具体如下: 1. 简介 zend_db_table_r...

本文实例讲述了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程序设计有所帮助。