Zend_Db_Table_Row.xml 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132
  1. <sect1 id="zend.db.table.row">
  2. <title>Zend_Db_Table_Row</title>
  3. <sect2 id="zend.db.table.row.introduction">
  4. <title>简介</title>
  5. <para>
  6. Zend_Db_Table_Row是Zend Framework的行数据网关.通常来说,你不可以自己实例化Zend_Db_Table_Row,
  7. 而是通过调用Zend_Db_Table::find()方法或者Zend_Db_Table::fetchRow()方法将Zend_Db_Table_Row作为
  8. 结果数据返回过来.一旦你得到来一个Zend_Db_Table_Row对象,你可以修改记录值(体现为类的属性)然后
  9. 调用save()方法可以将更改保存到原表上.
  10. </para>
  11. </sect2>
  12. <sect2 id="zend.db.table.row.fetch">
  13. <title>取回一条记录</title>
  14. <para>
  15. 首先,需要实例化一个Zend_Db_Table类.
  16. </para>
  17. <programlisting role="php"><![CDATA[<?php
  18. // 设置一个 adapter
  19. require_once 'Zend/Db.php';
  20. $params = array (
  21. 'host' => '127.0.0.1',
  22. 'username' => 'malory',
  23. 'password' => '******',
  24. 'dbname' => 'camelot'
  25. );
  26. $db = Zend_Db::factory('PDO_MYSQL', $params);
  27. // 为所有的Zend_Db_Table对象设置默认adapter
  28. require_once 'Zend/Db/Table.php';
  29. Zend_Db_Table::setDefaultAdapter($db);
  30. // 连接到数据库中的某一个表
  31. class RoundTable extends Zend_Db_Table {}
  32. $table = new RoundTable();
  33. ?>]]>
  34. </programlisting>
  35. <para>
  36. 接下来,使用Zend_Db_Table::find()方法和主键进行查询,或者使
  37. 用Zend_Db_Table::fetchRow()方法查询.得到的返回结果是一个Zend_Db_Table_Row
  38. 对象,该对象的属性名采用camelCaps的形式对应数据库中带下划线的表名.例如,表名
  39. 若为first_name,那么类中的改属性则为firstName.
  40. </para>
  41. <programlisting role="php"><![CDATA[<?php
  42. // 从表中取回的结果数据是一个Zend_Db_Table_Row对象
  43. $row = $table->fetchRow('first_name = "Robin"');
  44. //
  45. // $row现在是一个带有多种公有属性的Zend_Db_Table_Row对象
  46. // that map to table columns:
  47. //
  48. // $row->id = '3'
  49. // $row->nobleTitle = 'Sir'
  50. // $row->firstName = 'Robin'
  51. // $row->favoriteColor = 'yellow'
  52. //
  53. ?>]]>
  54. </programlisting>
  55. </sect2>
  56. <sect2 id="zend.db.table.row.modify">
  57. <title>修改数据</title>
  58. <para>
  59. 修改行数据是一件很轻松的事情:只需要按照常规的方法修改类属性.然后调用save()方法
  60. 就将改变的结果保存到了数据表中.
  61. </para>
  62. <programlisting role="php"><![CDATA[<?php
  63. // 连接到数据库中的表
  64. class RoundTable extends Zend_Db_Table {}
  65. $table = new RoundTable();
  66. // 从表中取回的结果数据是一个Zend_Db_Table_Row对象
  67. $row = $table->fetchRow('first_name = "Robin"');
  68. //
  69. // $row现在是一个带有多种公有属性的Zend_Db_Table_Row对象
  70. // that map to table columns:
  71. //
  72. // $row->id = '3'
  73. // $row->nobleTitle = 'Sir'
  74. // $row->firstName = 'Robin'
  75. // $row->favoriteColor = 'yellow'
  76. //
  77. // 改变favorite color字段,并且将变动存储到数据表中.
  78. $row->favoriteColor = 'blue';'
  79. $row->save();
  80. ?>]]>
  81. </programlisting>
  82. <para>
  83. 但是,你不能够修改主键的值.假如你试图进行改操作, Zend_Db_Table_Row将抛出一个异常.
  84. </para>
  85. <programlisting role="php"><![CDATA[<?php
  86. // 连接到数据库中的表
  87. class RoundTable extends Zend_Db_Table {}
  88. $table = new RoundTable();
  89. // fetch a record from the table as a Zend_Db_Table_Row object
  90. $row = $table->fetchRow('first_name = "Robin"');
  91. // 我们尝试修改主键值
  92. try {
  93. $row->id = 5;
  94. echo "We should not see this message, as an exception was thrown.";
  95. } catch (Zend_Db_Table_RowException $e) {
  96. echo $e->getMessage();
  97. }
  98. ?>]]>
  99. </programlisting>
  100. </sect2>
  101. </sect1>
  102. <!--
  103. vim:se ts=4 sw=4 et:
  104. -->