Zend_Db_Table_Rowset.xml 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105
  1. <sect1 id="zend.db.tablerowset">
  2. <title>Zend_Db_Table_Rowset</title>
  3. <sect2 id="zend.db.table.rowset.introduction">
  4. <title>简介</title>
  5. <para>
  6. Zend_Db_Table_Rowset是 Zend_Db_Table_Row对象集合的迭代器.通常来说,你不可以自己实例化Zend_Db_Table_Rowset,
  7. 而是通过调用Zend_Db_Table::find()方法或者fetchAll()方法将Zend_Db_Table_Rowset作为
  8. 结果数据返回过来.接下来就可以遍历Zend_Db_Table_Row对象集合并进行修改.
  9. </para>
  10. </sect2>
  11. <sect2 id="zend.db.table.rowset.fetch">
  12. <title>取回结果集</title>
  13. <para>
  14. 首先,需要实例化一个Zend_Db_Table类.
  15. </para>
  16. <programlisting role="php"><![CDATA[<?php
  17. // 设置一个 adapter
  18. require_once 'Zend/Db.php';
  19. $params = array (
  20. 'host' => '127.0.0.1',
  21. 'username' => 'malory',
  22. 'password' => '******',
  23. 'dbname' => 'camelot'
  24. );
  25. $db = Zend_Db::factory('PDO_MYSQL', $params);
  26. // 为所有的Zend_Db_Table对象设置默认
  27. require_once 'Zend/Db/Table.php';
  28. Zend_Db_Table::setDefaultAdapter($db);
  29. // 连接数据库表
  30. class RoundTable extends Zend_Db_Table {}
  31. $table = new RoundTable();
  32. ?>]]>
  33. </programlisting>
  34. <para>
  35. 接下来,可以使用Zend_Db_Table::find()方法和多个键值,或者使用Zend_Db_Table::fetchAll()方法对数据库进行查询,
  36. 返回的结果是一个Zend_Db_Table_Rowset对象,可以通过该对象遍历结果集中的每一个Zend_Db_Table_Row对象.
  37. </para>
  38. <programlisting role="php"><![CDATA[<?php
  39. // 从表中取回多条记录
  40. $rowset = $table->fetchAll();
  41. //
  42. // $rowset现在是一个Zend_Db_Table_Rowset对象,该对象中每条记录就是一个Zend_Db_Table_Row对象
  43. //
  44. ?>]]>
  45. </programlisting>
  46. </sect2>
  47. <sect2 id="zend.db.table.rowset.iterate">
  48. <title>遍历结果集</title>
  49. <para>
  50. Zend_Db_Table_Rowset实现了简单程序设计语言的迭代器接口,也就是说,可以对Zend_Db_Table_Rowset
  51. 对象进行循环处理,就像使用foreach()函数处理数组一样.使用这种方法取回的每一个值都是一个对应表
  52. 中数据的Zend_Db_Table_Row对象,你可以查看,修改和保存该对象的属性(即表中的字段值.)
  53. </para>
  54. <programlisting role="php"><![CDATA[<?php
  55. // 连接到数据库中的表
  56. class RoundTable extends Zend_Db_Table {}
  57. $table = new RoundTable();
  58. // 从表中取回多条记录
  59. $rowset = $table->fetchAll();
  60. // 显示所有的记录
  61. foreach ($rowset as $row) {
  62. // $row 是一个 Zend_Db_Table_Row 对象
  63. echo "<p>" . htmlspecialchars($row->nobleTitle) . " "
  64. . htmlspecialchars($row->firstName) . "'s "
  65. . "favorite color is " . htmlspecialchars($row->favoriteColor)
  66. . ".</p>\n";
  67. // 更新我们显示改行的次数
  68. // (对应表中的"times_displayed"字段)
  69. $row->timesDisplayed ++;
  70. // 保存新记录.
  71. $row->save();
  72. }
  73. ?>]]>
  74. </programlisting>
  75. </sect2>
  76. </sect1>
  77. <!--
  78. vim:se ts=4 sw=4 et:
  79. -->