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