Zend Framework框架教程之Zend_Db_Table_Rowset用法实例分析
本文实例讲述了ZendFramework框架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);
//连接数据库表
classRoundTableextendsZend_Db_Table{}
$table=newRoundTable();
?>
接下来,可以使用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
//连接到数据库中的表
classRoundTableextendsZend_Db_Table{}
$table=newRoundTable();
//从表中取回多条记录
$rowset=$table->fetchAll();
//显示所有的记录
foreach($rowsetas$row){
//$row是一个Zend_Db_Table_Row对象
echo"<p>".htmlspecialchars($row->nobleTitle).""
.htmlspecialchars($row->firstName)."'s"
."favoritecoloris".htmlspecialchars($row->favoriteColor)
.".</p>/n";
//更新我们显示改行的次数
//(对应表中的"times_displayed"字段)
$row->timesDisplayed++;
//保存新记录.
$row->save();
}
?>
更多关于zend相关内容感兴趣的读者可查看本站专题:《ZendFrameWork框架入门教程》、《php优秀开发框架总结》、《Yii框架入门及常用技巧总结》、《ThinkPHP入门教程》、《php面向对象程序设计入门教程》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总》
希望本文所述对大家基于ZendFramework框架的PHP程序设计有所帮助。