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 动态执行带有参数的类方法
Apr 10 PHP
PHP 开源框架22个简单简介
Aug 24 PHP
解析php安全性问题中的:Null 字符问题
Jun 21 PHP
PHP编译安装中遇到的两个错误和解决方法
Aug 20 PHP
PHP使用GETDATE获取当前日期时间作为一个关联数组的方法
Mar 19 PHP
PHP的Yii框架的常用日志操作总结
Dec 08 PHP
PHP实现动态添加XML中数据的方法
Mar 30 PHP
php基于Redis消息队列实现的消息推送的方法
Nov 28 PHP
PHP+redis实现的购物车单例类示例
Feb 02 PHP
PHP常量define和const的区别详解
May 18 PHP
laravel 实现根据字段不同值做不同查询
Oct 23 PHP
PHP数组Key强制类型转换实现原理解析
Sep 01 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
PHP动态变静态原理
2006/11/25 PHP
测试您的 PHP 水平的题目
2007/05/30 PHP
PHP 无限分类三种方式 非函数的递归调用!
2011/08/26 PHP
PHP设计模式之调解者模式的深入解析
2013/06/13 PHP
解析PHP将对象转换成数组的方法(兼容多维数组类型)
2013/06/21 PHP
封装ThinkPHP的一个文件上传方法实例
2014/10/31 PHP
Yii数据读取与跳转参数传递用法实例分析
2016/07/12 PHP
PHP策略模式定义与用法示例
2017/07/27 PHP
jscript之Open an Excel Spreadsheet
2007/06/13 Javascript
传智播客学习之JavaScript基础篇
2009/11/13 Javascript
基于jquery实现的定时显示与隐藏div广告的实现代码
2013/08/22 Javascript
JS二维数组的定义说明
2014/03/03 Javascript
javascript实现鼠标拖动改变层大小的方法
2015/04/30 Javascript
在Python中使用glob模块查找文件路径的方法
2015/06/17 Javascript
微信小程序 开发之快递查询功能的实现
2017/01/09 Javascript
vue axios 在页面切换时中断请求方法 ajax
2018/03/05 Javascript
vue路由对不同界面进行传参及跳转的总结
2019/04/20 Javascript
微信小程序在线客服自动回复功能(基于node)
2019/07/03 Javascript
mock.js模拟数据实现前后端分离
2019/07/24 Javascript
[09:34]2018DOTA2国际邀请赛寻真——永不放弃的iG
2018/08/14 DOTA
Python基于正则表达式实现检查文件内容的方法【文件检索】
2017/08/30 Python
Python实现线程状态监测简单示例
2018/03/28 Python
python pygame模块编写飞机大战
2018/11/20 Python
pandas对dataFrame中某一个列的数据进行处理的方法
2019/07/08 Python
css3闪亮进度条效果实现思路及代码
2013/04/17 HTML / CSS
HTML5不支持标签和新增标签详解
2016/06/27 HTML / CSS
英国羊皮鞋类领先品牌:Just Sheepskin
2019/12/12 全球购物
请编程遍历页面上所有 TextBox 控件并给它赋值为 string.Empty
2015/12/03 面试题
本科生的职业生涯规划范文
2014/01/09 职场文书
教师党员岗位承诺书
2014/05/29 职场文书
2014优秀党员事迹材料
2014/08/14 职场文书
答谢酒会主持词
2015/07/02 职场文书
安全生产感想
2015/08/07 职场文书
vue中三级导航的菜单权限控制
2021/03/31 Vue.js
MySQL 可扩展设计的基本原则
2021/05/14 MySQL
python 爬取哔哩哔哩up主信息和投稿视频
2021/06/07 Python