当前位置:首页 > PHP教程 > Zend > 列表

Zend Framework教程之Zend_Db_Table_Row用法实例分析

发布:smiling 来源: PHP粉丝网  添加日期:2021-07-20 21:08:36 浏览: 评论:0 

这篇文章主要介绍了Zend Framework教程之Zend_Db_Table_Row用法,详细讲述了Zend_Db_Table_Row的功能,并结合实例形式详细分析了Zend_Db_Table_Row操作数据的相关技巧,需要的朋友可以参考下。

本文实例讲述了Zend Framework教程之Zend_Db_Table_Row用法,分享给大家供大家参考,具体如下:

1. 简介

Zend_Db_Table_Row是Zend Framework的行数据网关.通常来说,你不可以自己实例化Zend_Db_Table_Row, 而是通过调用Zend_Db_Table::find()方法或者Zend_Db_Table::fetchRow()方法将Zend_Db_Table_Row作为 结果数据返回过来.一旦你得到来一个Zend_Db_Table_Row对象,你可以修改记录值(体现为类的属性)然后 调用save()方法可以将更改保存到原表上.

2. 取回一条记录

首先,需要实例化一个Zend_Db_Table类.

  1. <?php 
  2. // 设置一个 adapter 
  3. require_once 'Zend/Db.php'
  4. $params = array ( 
  5.   'host'   => '127.0.0.1'
  6.   'username' => 'malory'
  7.   'password' => '******'
  8.   'dbname'  => 'camelot' 
  9. ); 
  10. $db = Zend_Db::factory('PDO_MYSQL'$params); 
  11. // 为所有的Zend_Db_Table对象设置默认adapter 
  12. require_once 'Zend/Db/Table.php'
  13. Zend_Db_Table::setDefaultAdapter($db); 
  14. // 连接到数据库中的某一个表 
  15. class RoundTable extends Zend_Db_Table {} 
  16. $table = new RoundTable(); 
  17. ?> 

接下来,使用Zend_Db_Table::find()方法和主键进行查询,或者使 用Zend_Db_Table::fetchRow()方法查询.

得到的返回结果是一个Zend_Db_Table_Row 对象,该对象的属性名采用camelCaps的形式对应数据库中带下划线的表名.

如,表名 若为first_name,那么类中的改属性则为firstName.

  1. <?php 
  2. // 从表中取回的结果数据是一个Zend_Db_Table_Row对象 
  3. $row = $table->fetchRow('first_name = "Robin"'); 
  4. // 
  5. // $row现在是一个带有多种公有属性的Zend_Db_Table_Row对象 
  6. // that map to table columns: 
  7. // 
  8. // $row->id = '3' 
  9. // $row->nobleTitle = 'Sir' 
  10. // $row->firstName = 'Robin' 
  11. // $row->favoriteColor = 'yellow' 
  12. // 
  13. ?> 

3. 修改数据

修改行数据是一件很轻松的事情:只需要按照常规的方法修改类属性.然后调用save()方法 就将改变的结果保存到了数据表中.

  1. <?php 
  2. // 连接到数据库中的表 
  3. class RoundTable extends Zend_Db_Table {} 
  4. $table = new RoundTable(); 
  5. // 从表中取回的结果数据是一个Zend_Db_Table_Row对象 
  6. $row = $table->fetchRow('first_name = "Robin"'); 
  7. // 
  8. // $row现在是一个带有多种公有属性的Zend_Db_Table_Row对象 
  9. // that map to table columns: 
  10. // 
  11. // $row->id = '3' 
  12. // $row->nobleTitle = 'Sir' 
  13. // $row->firstName = 'Robin' 
  14. // $row->favoriteColor = 'yellow' 
  15. // 
  16. // 改变favorite color字段,并且将变动存储到数据表中. 
  17. $row->favoriteColor = 'blue'
  18. $row->save(); 
  19. ?> 

但是,你不能够修改主键的值.假如你试图进行改操作, Zend_Db_Table_Row将抛出一个异常.

  1. <?php 
  2. // 连接到数据库中的表 
  3. class RoundTable extends Zend_Db_Table {} 
  4. $table = new RoundTable(); 
  5. // fetch a record from the table as a Zend_Db_Table_Row object 
  6. $row = $table->fetchRow('first_name = "Robin"'); 
  7. // 我们尝试修改主键值 
  8. try { 
  9.   $row->id = 5; 
  10.   echo "We should not see this message, as an exception was thrown."
  11. } catch (Zend_Db_Table_RowException $e) { 
  12.   echo $e->getMessage(); 
  13. ?>

Tags: Framework Zend_Db_Table_Row

分享到: