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


Posted in PHP onMarch 21, 2016

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

PHP 相关文章推荐
php magic_quotes_gpc的一点认识与分析
Aug 18 PHP
php中几种常见安全设置详解
Apr 06 PHP
PHP 异步执行方法,模拟多线程的应用分析
Jun 03 PHP
php获取mysql字段名称和其它信息的例子
Apr 14 PHP
ThinkPHP多语言支持与多模板支持概述
Aug 22 PHP
php获取文章上一页与下一页的方法
Dec 01 PHP
php提示Warning:mysql_fetch_array() expects的解决方法
Dec 16 PHP
php获取远程文件的内容和大小
Nov 03 PHP
laravel学习教程之关联模型
Jul 30 PHP
探究Laravel使用env函数读取环境变量为null的问题
Dec 06 PHP
php微信公众号开发(2)百度BAE搭建和数据库使用
Dec 15 PHP
Laravel 自动转换长整型雪花 ID 为字符串的实现
Oct 27 PHP
Zend Framework教程之Zend_Db_Table_Row用法实例分析
Mar 21 #PHP
Zend Framework教程之Zend_Db_Table用法详解
Mar 21 #PHP
PHP函数checkdnsrr用法详解(Windows平台用法)
Mar 21 #PHP
PHP常见数组函数用法小结
Mar 21 #PHP
老司机传授Ubuntu下Apache+PHP+MySQL环境搭建攻略
Mar 20 #PHP
Zend Framework入门知识点小结
Mar 19 #PHP
Zend Framework缓存Cache用法简单实例
Mar 19 #PHP
You might like
收音机发烧友应当熟知的100条知识
2021/03/02 无线电
FleaPHP的安全设置方法
2008/09/15 PHP
用PHP的超级变量$_POST获取HTML表单(HTML Form) 数据
2011/05/07 PHP
从康盛产品(discuz)提取出来的模板类
2011/06/28 PHP
如何设置mysql允许外网访问
2013/06/04 PHP
Thinkphp3.2.3整合phpqrcode生成带logo的二维码
2016/07/21 PHP
Mac系统下搭建Nginx+php-fpm实例讲解
2020/12/15 PHP
可简单避免的三个JS发布错误的详细介绍
2013/08/02 Javascript
js简单实现交换Li的值
2014/05/22 Javascript
纯CSS3代码实现滑动开关效果
2015/08/19 Javascript
APP中javascript+css3实现下拉刷新效果
2016/01/27 Javascript
javaScript基础详解
2017/01/19 Javascript
Angular中ng-repeat与ul li的多层嵌套重复问题
2017/07/24 Javascript
最实用的JS数组函数整理
2017/12/05 Javascript
详解angularjs跨页面传参遇到的一些问题
2018/11/01 Javascript
JS实现图片幻灯片效果代码实例
2020/05/21 Javascript
js实现双人五子棋小游戏
2020/05/28 Javascript
vue@cli3项目模板怎么使用public目录下的静态文件
2020/07/07 Javascript
python多线程方式执行多个bat代码
2016/06/07 Python
通过Python 接口使用OpenCV的方法
2018/04/02 Python
PYcharm 激活方法(推荐)
2020/03/23 Python
pycharm激活方法到2099年(激活流程)
2020/09/22 Python
CSS3属性background-size使用指南
2014/12/09 HTML / CSS
laravel使用redis队列实例讲解
2021/03/23 PHP
员工培训邀请函
2014/02/02 职场文书
物流业务员岗位职责
2014/02/08 职场文书
工程质量月活动方案
2014/02/19 职场文书
新任教师自我鉴定
2014/02/24 职场文书
物流管理专业毕业生自荐信
2014/03/04 职场文书
监察建议书格式
2014/05/19 职场文书
山楂树之恋观后感
2015/06/11 职场文书
《秦兵马俑》教学反思
2016/02/24 职场文书
Python中OpenCV实现简单车牌字符切割
2021/06/11 Python
如何在python中实现ECDSA你知道吗
2021/11/23 Python
JavaScript流程控制(循环)
2021/12/06 Javascript
CentOS7 minimal 最小化安装网络设置过程
2022/12/24 Servers